您好,登錄后才能下訂單哦!
如何用JavaScript檢測(cè)離線/在線狀態(tài)?很多新手對(duì)此不是很清楚,為了幫助大家解決這個(gè)難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來(lái)學(xué)習(xí)下,希望你能有所收獲。
這兩年離線瀏覽技術(shù)越來(lái)越流行,最常見(jiàn)的就是HTML5移動(dòng)應(yīng)用里,有很多普通的Web app也使用了這些技術(shù)。但是,新技術(shù)的出現(xiàn)有時(shí)會(huì)給我們WEB開(kāi)發(fā)人員帶領(lǐng)額外的苦惱,比如,如何判斷用戶現(xiàn)在是在線還是離線?幸好,有矛就有盾,JavaScript里的navigator
對(duì)象幫我們解決這個(gè)問(wèn)題。
navigator.onLine
屬性能給我們提供一個(gè)布爾值,用來(lái)判斷用戶是否連接了互聯(lián)網(wǎng)。你可以這樣訪問(wèn)它:
if(navigator.onLine) { // true|false // ... }
沒(méi)有比這更簡(jiǎn)單的了!
我們除了能檢測(cè)這個(gè)離線/在線屬性值外,還可以綁定offline
和 online
事件:
function updateIndicator() { // 這時(shí)可以根據(jù)offline/online按鈕的顏色 } // 根據(jù)網(wǎng)絡(luò)連接情況更新在線狀態(tài) window.addEventListener('online', updateIndicator); window.addEventListener('offline', updateIndicator); updateIndicator();
當(dāng)然,老式的技術(shù)里也提供了相應(yīng)的方法,在body
標(biāo)記上使用ononline
和 onoffline
方法。
我可以想象到很多地方都需要使用這些事件和屬性。比如一種情況,當(dāng)用戶正在工作時(shí),斷網(wǎng)了,如果我們的WEB應(yīng)用可以檢測(cè)出這種狀態(tài),可以將用戶的寫(xiě)作保持到本地的Web Storage里,等網(wǎng)絡(luò)恢復(fù)后,再提交到服務(wù)器上,這樣,斷網(wǎng)將不會(huì)給用戶的寫(xiě)作帶來(lái)影響。這只是一個(gè)簡(jiǎn)單的例子,相信你能想出更多。
需要提醒的是,這個(gè)API并不是那么可靠。最古老的定時(shí)刷新的技術(shù)可以當(dāng)做一種備案。
看完上述內(nèi)容是否對(duì)您有幫助呢?如果還想對(duì)相關(guān)知識(shí)有進(jìn)一步的了解或閱讀更多相關(guān)文章,請(qǐng)關(guān)注億速云行業(yè)資訊頻道,感謝您對(duì)億速云的支持。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。