日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
如何處理瀏覽器的斷網(wǎng)情況?

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

壞的斷網(wǎng)處理甚至不處理會出bug:比如我手上的項目就出了個bug 業(yè)務人員表示非??鄲?/p>

網(wǎng)絡問題一直是一個很值得關(guān)注的問題。

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

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

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

因此我將在這里記錄一下自己對系統(tǒng)斷網(wǎng)情況下的處理,一方面避免bug產(chǎn)生,一方面保證用戶及時在應用內(nèi)知道網(wǎng)絡已經(jīng)斷開連接

概覽

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

概覽

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

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

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

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

通??梢酝ㄟ^online/offline事件去做這個事情。

用于檢測瀏覽器是否連網(wǎng)的navigator.onLine

navigator.onLine

  • true online
  • false offline

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

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

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)...

用于檢測網(wǎng)絡狀況的navigator.connection

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

國內(nèi)的視頻網(wǎng)站也會給出一個切換網(wǎng)絡的提醒,該如何去檢測呢?

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

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

navigator.connection

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

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

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

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

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

常見網(wǎng)絡情況rtt和downlink表

網(wǎng)絡狀況 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時,可能它現(xiàn)在是rtt 100ms,2.2Mb/s,下一秒就變成125ms,2.1Mb/s了。

rtt

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

downlink

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

草案(Draft)階段NetworkInformation API

無論是rtt,還是downlink,都是這個草案中的內(nèi)容。

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

更多資料可以查詢:NetworkInformation

如何檢測網(wǎng)絡變化去做出響應呢?

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

例如可以獲得網(wǎng)絡狀況的變更?

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

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

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

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

斷網(wǎng)事件"offline"和連網(wǎng)事件"online"

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

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

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

事件是不能去取消的(開發(fā)者在代碼上不能手動變?yōu)閛nline或者offline,開發(fā)時使用開發(fā)者工具可以)。

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

最最建議window+addEventListener的組合。

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

例子

 
 
 
 
 
  •  
     
     
     
     
    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是在標簽節(jié)點的鄰近位置插入,可以查閱:DOM進階之insertAdjacentHTML

    斷網(wǎng)處理項目實戰(zhàn)

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

    思路和效果

    只要做到斷網(wǎng)提醒+遮罩,上線提醒-遮罩即可。

    • 監(jiān)聽offline,斷網(wǎng)給出提醒和遮罩:網(wǎng)絡已斷開,請檢查網(wǎng)絡連接。
    • 監(jiān)聽online,連網(wǎng)給出提醒和遮罩:網(wǎng)絡已連接。

    斷網(wǎng)處理組件使用

     
     
     
     
    1.     :offlineTitle = "斷網(wǎng)處理標題" 
    2.     :desc="斷網(wǎng)處理描述" 
    3.     :onlineTitle="連網(wǎng)提醒" 
    4.  

    斷網(wǎng)處理組件詳情

     
     
     
     
    1.  
    2.  
    3.  
    4.  
    5. .offline-mark { 
    6.   position: fixed; 
    7.   top: 0; 
    8.   left: 0; 
    9.   right: 0; 
    10.   bottom: 0; 
    11.   background-color: #ccc; 
    12.   z-index: 9999; 
    13.   transition: position 2s; 
    14. /deep/.ivu-spin-fix { 
    15.   text-align: left; 
    16.   font-size: 20px; 
    17.   h2 { 
    18.     color: rgba(0, 0, 0, 0.8); 
    19.   } 
    20.   p { 
    21.     margin-top: 20px; 
    22.     color: red; 
    23.     font-weight: bold; 
    24.   } 
    25.  

    發(fā)現(xiàn)

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

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

    運行環(huán)境:"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的避免屏閃

    當前標題:如何處理瀏覽器的斷網(wǎng)情況?
    轉(zhuǎn)載來于:http://m.5511xx.com/article/dpsjeog.html