亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么處理瀏覽器的斷網情況

發布時間:2021-10-23 16:30:57 來源:億速云 閱讀:461 作者:iii 欄目:web開發

本篇內容主要講解“怎么處理瀏覽器的斷網情況”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“怎么處理瀏覽器的斷網情況”吧!

概覽

為了構建一個 “斷網(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);

{      onchange: null,      effectiveType: "4g",      rtt: 50,      downlink: 2,      saveData: false  }

通過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)
online1002.2
fast 3g6001.55
slow 3g21500.4
offline00

注意: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事件去做一些響應。

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

var connection = navigator.connection;  var type = connection.effectiveType;  function updateConnectionStatus() {    console.log("網絡狀況從 " + type + " 切換至" + connection.effectiveType);    type = connection.effectiveType;  }  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>

例子

怎么處理瀏覽器的斷網情況

怎么處理瀏覽器的斷網情況

<div id="status"></div>  <div id="log"></div>
window.addEventListener('load', function() {    var status = document.getElementById("status");    var log = document.getElementById("log");    function updateOnlineStatus(event) {      var condition = navigator.onLine ? "online" : "offline";      status.innerHTML = condition.toUpperCase();      log.insertAdjacentHTML("beforeend", "Event: " + event.type + "; Status: " + condition);    }    window.addEventListener('online',  updateOnlineStatus);    window.addEventListener('offline', updateOnlineStatus);  });

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

斷網處理項目實戰

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

思路和效果

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

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

  • 監聽online,連網給出提醒和遮罩:網絡已連接。

怎么處理瀏覽器的斷網情況

斷網處理組件使用

<OfflineHandle      :offlineTitle = "斷網處理標題"      :desc="斷網處理描述"      :onlineTitle="連網提醒"  >  </OfflineHandle>

斷網處理組件詳情

<!--OfflineHandle.vue-->  <template>    <div v-if="spin" class="offline-mark">      <Spin size="large" fix>        <h3>{{offlineTitle}}</h3>        <p>{{desc}}</p>      </Spin>    </div>  </template>  <script>  export default {    name: 'offline-handle',    props: {      offlineTitle: {        type: String,        default: '網絡已斷開,請檢查網絡連接。',      },      onlineTitle: {        type: String,        default: '網絡已連接',      },      desc: {        type: String,        default: '',      },      duration: {        type: Number,        default: 4.5,      },    },    data() {      return {        spin: false,      };    },    mounted() {      window.addEventListener('offline', this.eventHandle);      window.addEventListener('online', this.eventHandle);    },    beforeDestroy() {      window.removeEventListener('offline', this.eventHandle);      window.removeEventListener('online', this.eventHandle);    },    methods: {      eventHandle(event) {        const type = event.type === 'offline' ? 'error' : 'success';        this.$Notice[type]({          title: type === 'error' ? this.offlineTitle : this.onlineTitle,          desc: type === 'error' ? this.desc : '',          duration: this.duration,        });        setTimeout(() => {          this.spin = event.type === 'offline';        }, 1500);      },    },  };  </script>  <style lang="scss" scoped>  .offline-mark {    position: fixed;    top: 0;    left: 0;    right: 0;    bottom: 0;    background-color: #ccc;    z-index: 9999;    transition: position 2s;  }  /deep/.ivu-spin-fix {    text-align: left;    font-size: 20px;    h3 {      color: rgba(0, 0, 0, 0.8);    }    p {      margin-top: 20px;      color: red;      font-weight: bold;    }  }  </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的避免屏閃 

到此,相信大家對“怎么處理瀏覽器的斷網情況”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

南城县| 永仁县| 邯郸县| 资兴市| 太保市| 延川县| 江口县| 巴南区| 电白县| 中方县| 抚宁县| 崇左市| 平湖市| 弋阳县| 开江县| 扎兰屯市| 留坝县| 清丰县| 四川省| 托克逊县| 葫芦岛市| 双桥区| 新乡县| 元谋县| 横山县| 黄陵县| 庆阳市| 阳泉市| 行唐县| 砚山县| 来凤县| 长丰县| 滦南县| 延安市| 闽清县| 杭锦后旗| 紫阳县| 太康县| 桐庐县| 曲水县| 苍南县|