精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

如何處理瀏覽器的斷網情況?

開發 前端
我將在這里記錄一下自己對系統斷網情況下的處理,一方面避免bug產生,一方面保證用戶及時在應用內知道網絡已經斷開連接。

 [[353877]]

好的斷網處理會讓人很舒適:lol的斷線重連,王者榮耀的斷線重連 可以確保游戲的繼續進行

壞的斷網處理甚至不處理會出bug:比如我手上的項目就出了個bug 業務人員表示非常苦惱

網絡問題一直是一個很值得關注的問題。

比如在慢網情況下,增加loading避免重復發請求,使用promise順序處理請求的返回結果,或者是增加一些友好的上傳進度提示等等。

那么大家有沒有想過斷網情況下該怎么做呢?比如說網絡正常->斷網->網絡正常。

其實我一直也沒想過,直到組里的測試測出一個斷網導致的bug,讓我意識到重度依賴網絡請求的前端,在斷網情況下可能會出現嚴重的bug。

因此我將在這里記錄一下自己對系統斷網情況下的處理,一方面避免bug產生,一方面保證用戶及時在應用內知道網絡已經斷開連接

概覽

  • 用于檢測瀏覽器是否連網的navigator.onLine
  • 用于檢測網絡狀況的navigator.connection
  • 斷網事件"offline"和連網事件"online"
  • 斷網處理項目實戰
    • 思路和效果
    • 斷網處理組件使用
    • 斷網處理組件詳情
    • 發現
  • 參考資料

概覽

為了構建一個 “斷網(offline)可用”的web應用,你需要知道應用在什么時候是斷網(offline)的。

不僅僅要知道什么時候斷網,更要知道什么時候網絡恢復正常(online)。

可以分解陳本下面兩種常見情況:

  1. 你需要知道用戶何時online,這樣你可以與服務器之間re-sync(重新同步)。
  2. 你需要知道用戶何時offline,這樣你可以將你未發出的請求過一段時間再向服務器發出。

通常可以通過online/offline事件去做這個事情。

用于檢測瀏覽器是否連網的navigator.onLine

navigator.onLine

  • true online
  • false offline

可以通過network的online選項切換為offline,打印navigator.onLine驗證。

當瀏覽器不能連接到網絡時,這個屬性會更新。規范中是這樣定義的:

The navigator.onLine attribute must return false if the user agent will not contact the network when the user follows links or when a script requests a remote page (or knows that such an attempt would fail)...

用于檢測網絡狀況的navigator.connection

在youtube觀看視頻時,自動檢測網絡狀況切換清晰度是如何做到的呢?

國內的視頻網站也會給出一個切換網絡的提醒,該如何去檢測呢?

也就是說,有沒有辦法檢測網絡狀況?判斷當前網絡是流暢,擁堵,繁忙呢?

可以通過navigator.connection,屬性包括effectiveType,rtt,downlink和變更網絡事件change。繼承自NetworkInformation API。

navigator.connection

online狀態下運行console.log(navigator.connection); 

  1.  
  2.     onchange: null,  
  3.     effectiveType: "4g",  
  4.     rtt: 50,  
  5.     downlink: 2,  
  6.     saveData: false  
  7.  

通過navigator.connection可以判斷出online,fast 3g,slow 3g,和offline,這四種狀態下的effectiveType分別為4g,3g,2g,4g(rtt,downlink均為0)。

rtt和downlink是什么?NetworkInformation是什么?

這是兩個反映網絡狀況的參數,比type更加具象且更能反映當前網絡的真實情況。

常見網絡情況rtt和downlink表

網絡狀況 rtt(ms) downlink(Mbit/s)
online 100 2.2
fast 3g 600 1.55
slow 3g 2150 0.4
offline 0 0

注意:rtt和downlink不是定值,而是實時變化的。online時,可能它現在是rtt 100ms,2.2Mb/s,下一秒就變成125ms,2.1Mb/s了。

rtt

  • 連接預估往返時間
  • 單位為ms
  • 值為四舍五入到25毫秒的最接近倍數(就是說這個值x%25===0,可以觀察常見網絡情況rtt和downlink表)
  • 值越小網速越快。類似ping的time吧
  • 在Web Worker中可用

downlink

  • 帶寬預估值
  • 單位為Mbit/s(注意是Mbit,不是MByte。)
  • 值也是四舍五入到最接近的25比特/秒的倍數(就是說這個值x%25===0,可以觀察常見網絡情況rtt和downlink表)
  • 一般越寬速度越快,也就是,信道上可以傳輸更多數。(吐槽一句,學過的通信原理還蠻有用。)
  • 值越大網速越快。類似高速一般比國道寬。
  • 在Web Worker中可用

草案(Draft)階段NetworkInformation API

無論是rtt,還是downlink,都是這個草案中的內容。

除此之外還有downlinkMax,saveData,type等屬性。

更多資料可以查詢:NetworkInformation

如何檢測網絡變化去做出響應呢?

NetworkInformation繼承自EventTarget,可以通過監聽change事件去做一些響應。

例如可以獲得網絡狀況的變更? 

  1. var connection = navigator.connection;  
  2. var type = connection.effectiveType;  
  3. function updateConnectionStatus() {  
  4.   console.log("網絡狀況從 " + type + " 切換至" + connection.effectiveType);  
  5.   type = connection.effectiveType;  
  6.  
  7. connection.addEventListener('change', updateConnectionStatus); 

 監聽變更之后,我們可以彈一個Modal提醒用戶,也可以出一個Notice通知用戶網絡有變化,或者可以更高級得去自動切換清晰度(這個應該比較難)。

引出NetworkInformation的概念,只是想起一個拋磚引玉的作用。這種細粒度的網絡狀況檢測,可以結合具體需求去具體實現。

在這篇博文中,我們只處理斷網和連網兩種情況,下面來看斷網事件"offline"和連網事件"online"。

斷網事件"offline"和連網事件"online"

瀏覽器有兩個事件:"online" 和 "offline".

這兩個事件會在瀏覽器在online mode和offline mode之間切換時,由頁面的<body>發射出去。

事件會按照以下順序冒泡:document.body -> document -> window。

事件是不能去取消的(開發者在代碼上不能手動變為online或者offline,開發時使用開發者工具可以)。

注冊上下線事件的幾種方式

最最建議window+addEventListener的組合。

  • 通過window或document或document.body和addEventListener(Chrome80僅window有效)
  • 為document或document.body的.ononline或.onoffline屬性設置一個js函數。(注意,使用window.ononline和window.onoffline會有兼容性的問題)
  • 也可以通過標簽注冊事件<body ononline="onlineCb" onoffline="offlineCb"></body>

例子

 

  1. <div id="status"></div>  
  2. <div id="log"></div>  
  1. window.addEventListener('load', function() {  
  2.   var status = document.getElementById("status");  
  3.   var log = document.getElementById("log");  
  4.   function updateOnlineStatus(event) {  
  5.     var condition = navigator.onLine ? "online" : "offline";  
  6.     status.innerHTML = condition.toUpperCase();  
  7.     log.insertAdjacentHTML("beforeend", "Event: " + event.type + "; Status: " + condition);  
  8.   }  
  9.   window.addEventListener('online',  updateOnlineStatus);  
  10.   window.addEventListener('offline', updateOnlineStatus);  
  11. }); 

其中insertAdjacentHTML是在標簽節點的鄰近位置插入,可以查閱:DOM進階之insertAdjacentHTML

斷網處理項目實戰

基于vue以及iView的Spin,Notice組件封裝出離線處理組件,在需要到的頁面引入即可。

思路和效果

只要做到斷網提醒+遮罩,上線提醒-遮罩即可。

  • 監聽offline,斷網給出提醒和遮罩:網絡已斷開,請檢查網絡連接。
  • 監聽online,連網給出提醒和遮罩:網絡已連接。

 

斷網處理組件使用 

  1. <OfflineHandle  
  2.     :offlineTitle = "斷網處理標題"  
  3.     :desc="斷網處理描述"  
  4.     :onlineTitle="連網提醒"  
  5. >  
  6. </OfflineHandle>  

斷網處理組件詳情 

  1. <!--OfflineHandle.vue-->  
  2. <template>  
  3.   <div v-if="spin" class="offline-mark">  
  4.     <Spin size="large" fix>  
  5.       <h2>{{offlineTitle}}</h2>  
  6.       <p>{{desc}}</p>  
  7.     </Spin>  
  8.   </div>  
  9. </template>  
  10. <script>  
  11. export default {  
  12.   name: 'offline-handle',  
  13.   props: {  
  14.     offlineTitle: {  
  15.       type: String,  
  16.       default: '網絡已斷開,請檢查網絡連接。',  
  17.     },  
  18.     onlineTitle: {  
  19.       type: String,  
  20.       default: '網絡已連接',  
  21.     },  
  22.     desc: {  
  23.       type: String,  
  24.       default: '',  
  25.     },  
  26.     duration: {  
  27.       type: Number,  
  28.       default: 4.5,  
  29.     },  
  30.   },  
  31.   data() {  
  32.     return {  
  33.       spin: false,  
  34.     };  
  35.   },  
  36.   mounted() {  
  37.     window.addEventListener('offline', this.eventHandle);  
  38.     window.addEventListener('online', this.eventHandle);  
  39.   },  
  40.   beforeDestroy() { 
  41.      window.removeEventListener('offline', this.eventHandle);  
  42.     window.removeEventListener('online', this.eventHandle);  
  43.   },  
  44.   methods: {  
  45.     eventHandle(event) {  
  46.       const type = event.type === 'offline' ? 'error' : 'success';  
  47.       this.$Notice[type]({  
  48.         title: type === 'error' ? this.offlineTitle : this.onlineTitle,  
  49.         desc: type === 'error' ? this.desc : '',  
  50.         duration: this.duration,  
  51.       }); 
  52.        setTimeout(() => {  
  53.         this.spin = event.type === 'offline';  
  54.       }, 1500);  
  55.     },  
  56.   },  
  57. };  
  58. </script>  
  59. <style lang="scss" scoped>  
  60. .offline-mark {  
  61.   position: fixed;  
  62.   top: 0;  
  63.   left: 0;  
  64.   right: 0;  
  65.   bottom: 0;  
  66.   background-color: #ccc;  
  67.   z-index: 9999;  
  68.   transition: position 2s;  
  69.  
  70. /deep/.ivu-spin-fix {  
  71.   text-align: left;  
  72.   font-size: 20px;  
  73.   h2 {  
  74.     color: rgba(0, 0, 0, 0.8);  
  75.   }  
  76.   p {  
  77.     margin-top: 20px;  
  78.     color: red;  
  79.     font-weight: bold;  
  80.   }  
  81.  
  82. </style>  

發現

  • offline和online事件:window有效,document和document.body設置無效

手上的項目只運行在Chrome瀏覽器,只有為window設置offline和online才生效。

運行環境:"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/80.0.3987.149 Safari/537.36

  • 為position增加2s的transition的避免屏閃 

 

責任編輯:龐桂玉 來源: segmentfault
相關推薦

2012-04-23 13:43:02

HTML5瀏覽器

2021-08-18 08:20:14

SQL除數統計

2010-04-05 21:57:14

Netscape瀏覽器

2013-11-18 14:42:53

瀏覽器渲染

2012-03-20 11:31:58

移動瀏覽器

2012-03-20 11:41:18

海豚瀏覽器

2012-03-19 17:25:22

2012-03-20 11:07:08

2012-12-10 11:29:21

瀏覽器搜狗

2013-07-25 14:17:17

2010-12-21 10:11:35

手機瀏覽器

2013-01-14 10:58:51

傲游云瀏覽器

2012-06-21 15:38:02

獵豹瀏覽器

2012-03-19 17:17:00

移動瀏覽器歐朋

2012-03-20 11:22:02

QQ手機瀏覽器

2009-06-22 14:06:00

java瀏覽器

2010-09-01 15:40:10

DHCP服務器

2015-07-23 10:17:27

瀏覽器內核

2019-07-16 07:15:42

瀏覽器網絡威脅網絡安全

2015-09-15 14:02:57

DNS解析
點贊
收藏

51CTO技術棧公眾號

亚洲一区二区三区视频| 国产在线视频一区二区三区| 精品国产乱码久久久久久免费| 丁香花在线影院观看在线播放| 日本一区视频| 久久66热re国产| 91极品女神在线| 在线观看亚洲网站| 精品一区亚洲| 欧美一二三四区在线| 日本老熟妇毛茸茸| 国产色婷婷在线| 国产精品福利av| 久精品国产欧美| 国产a级免费视频| 日韩av一二三| 欧美一级片久久久久久久| 日韩激情小视频| 国内成人精品| 亚洲精品美女免费| xxxx视频在线观看| 国产国产一区| 在线影视一区二区三区| 青青青免费在线| av免费在线免费观看| 欧美国产精品一区二区| 免费av一区二区三区| www.com欧美| 麻豆国产精品视频| 国产成人精品视频在线| 精品成人久久久| 欧美人与禽猛交乱配视频| 精品国偷自产在线视频99| 日本人亚洲人jjzzjjz| 亚洲理论电影片| 日韩不卡在线观看| 污污免费在线观看| 999在线精品| 欧美激情偷拍自拍| 亚洲一区二区三区四区在线观看 | 成人综合一区| 亚洲精品中文字幕av| 国产美女视频免费观看下载软件| 日韩精品一级| 日韩视频在线永久播放| 久久精品国产露脸对白| 久久91超碰青草在哪里看| 在线亚洲一区二区| 天天操,天天操| 精品久久福利| 欧美一区二区三区男人的天堂| 一本一道久久a久久综合蜜桃| 人人精品久久| 91精品久久久久久久久99蜜臂| 日本不卡一区二区在线观看| 色综合视频一区二区三区44| 欧美丰满美乳xxx高潮www| 91亚洲免费视频| 伊人久久大香| 欧美一区二区三区播放老司机| 国产成人强伦免费视频网站| 免费一级欧美片在线观看网站| 日韩女优视频免费观看| 亚洲女则毛耸耸bbw| 国产精品网址| 亚洲人成网站999久久久综合| 精品无码人妻一区二区免费蜜桃| 精品理论电影在线| 久久久国产91| 国产精品99精品| 美女国产一区| 国产精品女主播| 国产精品热久久| 国产真实乱偷精品视频免| 99re国产| 男男激情在线| 国产精品久久久久9999吃药| 无码人妻精品一区二区三区99v| 国产一线二线在线观看| 日韩欧美精品网站| 精品综合久久久久| 农村少妇一区二区三区四区五区| 亚洲色图综合久久| 538精品在线视频| 一区二区三区高清视频在线观看| 国产va免费精品高清在线观看| 亚洲午夜激情视频| 成人小视频免费观看| 日本视频一区二区不卡| a级网站在线播放| 精品日韩视频在线观看| 亚洲天堂国产视频| 欧美三级自拍| 久久精品国产视频| 日本熟妇毛茸茸丰满| 麻豆免费精品视频| 精品欧美一区二区久久久伦| 美女黄视频在线观看| 亚洲猫色日本管| 色婷婷综合久久久久中文字幕| 久久av网站| 一区二区三区四区视频| 懂色av.com| 精品一区二区三区香蕉蜜桃| 久久精品人人做人人爽电影| 老司机在线视频二区| 日韩欧美视频一区二区三区| 精品亚洲一区二区三区四区| 日韩成人一级| 萌白酱国产一区二区| 少妇一级淫片日本| eeuss影院一区二区三区| 99久久久无码国产精品性色戒| 韩国久久久久久| 精品国产乱码久久久久久闺蜜| 一区二区三区在线播放视频| 亚洲中字黄色| 国产欧美日韩伦理| av网址在线免费观看| 欧美在线免费播放| 国产偷人妻精品一区| 激情欧美日韩| 91手机在线视频| caoporn97在线视频| 欧美日韩一区三区| 国产成人精品无码免费看夜聊软件| 黑丝一区二区| 99国内精品久久久久久久软件| 香蕉视频在线播放| 欧美三级电影网站| 人妻少妇无码精品视频区| 一区二区黄色| 国产一区二区精品在线| 里番在线播放| 精品国内二区三区| 免看一级a毛片一片成人不卡| 紧缚奴在线一区二区三区| 四虎一区二区| 日本综合视频| 色阁综合伊人av| 亚洲视频一区二区三区四区| 中文字幕第一区综合| 毛片毛片毛片毛片毛片毛片毛片毛片毛片| 日韩动漫一区| 欧美在线性视频| 麻豆av电影在线观看| 日韩欧美中文免费| 国产伦理片在线观看| 石原莉奈一区二区三区在线观看| 欧美一级二级三级九九九| 欧美大胆成人| 国产一区二区三区日韩欧美| 国产精品无码粉嫩小泬| 欧美激情一区二区三区不卡| 性欧美videossex精品| 99精品美女| 亚洲va男人天堂| 牛牛在线精品视频| 亚洲高清久久网| 亚洲天堂视频网站| 国产无一区二区| 日韩在线一区视频| 国产精品videosex极品| 国产精品美女黄网| 周于希免费高清在线观看| 亚洲性线免费观看视频成熟| 亚洲图片视频小说| 亚洲综合激情另类小说区| 亚洲天堂资源在线| 日韩一区精品视频| 中文字幕一区二区中文字幕| 亚洲精品一区国产| 欧美夜福利tv在线| 午夜免费福利在线观看| 欧美大片一区二区| 在线天堂中文字幕| 亚洲手机成人高清视频| 漂亮人妻被黑人久久精品| 日韩精品一级中文字幕精品视频免费观看 | 午夜精品久久久久久久96蜜桃 | 999精品国产| 五月激情六月综合| 国产三级aaa| 成人国产免费视频| xxx国产在线观看| 亚洲午夜精品久久久久久app| 欧美极品jizzhd欧美| 99久久亚洲国产日韩美女 | 国产无遮无挡120秒| 国产日韩三级在线| 亚洲一级Av无码毛片久久精品| 视频一区二区国产| 日韩极品视频在线观看| 精品日韩毛片| 国产成人亚洲欧美| 欧美成人一二区| 国产69久久精品成人| 国产激情视频在线| 亚洲天堂男人天堂| 高h震动喷水双性1v1| 欧美亚洲日本国产| 国产无遮挡又黄又爽又色| 亚洲色图欧洲色图| 免费在线观看污| 成人蜜臀av电影| 91日韩精品视频| 久久一区二区三区四区五区| 国产a级黄色大片| 色综合天天爱| 日产中文字幕在线精品一区| 国产精品15p| 91热福利电影| 欧美一区=区三区| 国产精品成av人在线视午夜片| 久久一卡二卡| 久久精品夜夜夜夜夜久久| 国产视频精品久久| 日韩电影免费观看中文字幕| 亚洲国产精品视频在线| 欧美精品日韩一本| 最好看的日本字幕mv视频大全| 欧美日韩免费一区| 国产精品18p| 亚洲成人一区在线| 免费毛片在线播放免费 | 欧美一级中文字幕| 91精品国产调教在线观看| 香蕉久久夜色| 红桃视频在线观看一区二区| 久久综合九九| 麻豆精品av| 久久日韩精品| 全球av集中精品导航福利| 国产乱码精品一区二区三区卡 | 欧美xxxx在线观看| 国产福利第一页| 欧美一区二区三区视频免费播放| 国产免费黄色网址| 欧美一区二区大片| www.天堂av.com| 日韩一卡二卡三卡国产欧美| 国产黄色免费大片| 欧美成人精品1314www| 午夜免费福利视频| 精品国偷自产国产一区| 色窝窝无码一区二区三区成人网站 | 6080国产精品| 国产资源精品在线观看| a级大片免费看| 成人h动漫精品一区二区| 美女扒开腿免费视频| 97精品超碰一区二区三区| 亚洲熟妇一区二区三区| 国产偷国产偷亚洲高清人白洁| 一区二区三区在线观看免费视频| 亚洲国产精品99久久久久久久久 | 亚洲国产另类av| 国产精品6666| 日本韩国一区二区| 91亚洲欧美激情| 欧美一级欧美三级在线观看 | av一二三不卡影片| 少妇精品一区二区三区| 国产欧美一区二区精品性| 欧美日韩中文字幕视频| 亚洲三级在线看| 久久视频免费在线观看| 狠狠做深爱婷婷久久综合一区 | 国产免费不卡| 成人免费直播live| 一区二区三区亚洲变态调教大结局 | 亚洲综合丝袜美腿| 久热这里只有精品6| 欧美性videosxxxxx| xxxwww在线观看| 亚洲欧美国产一本综合首页| 黄色免费在线看| 91爱视频在线| 日韩一区二区三区四区五区| 高清视频一区二区三区| 精品日韩欧美一区| 青春草国产视频| 日本欧美在线观看| 4438x全国最大成人| 久久久国产一区二区三区四区小说| 三级黄色在线观看| 图片区小说区国产精品视频| 91porny九色| 亚洲精品在线三区| 日p在线观看| 91av在线看| 无码国模国产在线观看| 欧洲精品码一区二区三区免费看| 欧美区一区二| 亚洲欧美在线精品| 99国产精品国产精品久久| 青青草自拍偷拍| 精品久久香蕉国产线看观看亚洲| 国产又爽又黄又嫩又猛又粗| 日韩精品视频免费在线观看| 国产黄a三级三级三级av在线看| 欧美影院在线播放| 中文字幕久久精品一区二区| 亚洲一区二区三区午夜| 久久综合五月| 男男做爰猛烈叫床爽爽小说| 亚洲欧美韩国综合色| 国产成人a v| 亚洲精品久久久久久久久久久久久| 国产原创在线观看| 国产精品爽黄69天堂a| 国内露脸中年夫妇交换精品| 中文字幕中文字幕在线中心一区| 久久蜜桃资源一区二区老牛| 中文字幕一区二区人妻电影丶| 国产精品大尺度| 国产精品第6页| 日韩精品在线观看一区二区| av在线播放资源| 成人欧美视频在线| 亚洲深深色噜噜狠狠爱网站| 中文字幕中文在线| 国产精品高潮久久久久无| 草莓视频18免费观看| 亚洲男人天堂视频| 9999精品成人免费毛片在线看| 97夜夜澡人人双人人人喊| 天天色综合色| 岛国av免费在线| **网站欧美大片在线观看| 亚洲一区二区激情| 主播福利视频一区| 78精品国产综合久久香蕉| 日韩欧美精品一区二区三区经典| 久久亚洲图片| 亚洲а∨天堂久久精品2021| 欧美在线看片a免费观看| 成人动漫在线免费观看| 国产精品国内视频| 日韩在线不卡| 午夜精品免费看| 一区二区三区丝袜| 成人1区2区3区| 久久久影视精品| 欧美巨大xxxx| 成人久久久久久久久| 久久久美女毛片| jizz国产在线| 日韩一级裸体免费视频| 精品午夜视频| 免费人成自慰网站| 91丨国产丨九色丨pron| 99精品在线播放| 亚洲裸体xxxx| 欧美高清你懂的| 樱空桃在线播放| 成人免费高清在线| 成人公开免费视频| 色偷偷噜噜噜亚洲男人| 日韩中文在线| 国产视频九色蝌蚪| 国产午夜三级一区二区三| 一区二区www| 欧美国产乱视频| 香蕉国产成人午夜av影院| 亚洲不卡视频在线| 亚洲精品高清在线观看| 亚洲av片在线观看| 国产精品视频专区| 欧美精品福利| 亚欧洲乱码视频| 欧美精品久久天天躁| japanese色国产在线看视频| 日本成人三级电影网站| 国产精品白丝jk黑袜喷水| 91av在线免费视频| 色偷偷av一区二区三区| 丁香婷婷成人| 妺妺窝人体色www在线观看| 亚洲欧美日韩在线播放| 日本福利午夜视频在线| 亚洲www在线观看| 国产精品亚洲综合色区韩国| 成人做爰视频网站| 亚洲另类图片色| 日韩精品一区二区三区中文在线| 欧美亚洲另类色图| 亚洲乱码一区二区三区在线观看| 四虎影院在线播放| 91在线观看免费高清| 国产农村妇女精品一二区| 91传媒免费观看| 亚洲人成77777在线观看网| 日本一区二区三区电影免费观看| 黄色国产精品视频| 亚洲在线视频一区| 日本综合在线| 欧美日韩亚洲一区二区三区在线观看 | 国产欧美一区二区色老头 | 在线免费观看不卡av|