JS判斷有無網絡(移動端)


ar EventUtil = { addHandler: function (element, type, handler) { if (element.addEventListener) { element.addEventListener(type, handler, false); } else if (element.attachEvent) { element.attachEvent("on" + type, handler); } else { element["on" + type] = handler; } } };
EventUtil.addHandler(window, "online", function () { alert("Online");
}); EventUtil.addHandler(window, "offline", function () {
alert("Offline"); });
 
當然,如果想支持的更兼容,可以使用如下2個事件:online和offline。當網絡從離線變為在線或者從在線變為離線時,分別觸發這兩個事件。這兩個事件在window對象上觸發。
為了檢測應用是否離線,在頁面加載后,最好先通過navigator.onLine取得初始的狀態。然后,就是通過上述兩個事件來確定網絡連接狀態是否變化。當上述事件觸發式,navigator.onLine屬性的值也會改變,不過必須要手工輪詢這個屬性才能檢測到網絡狀態的變化。
 
方法一: navigator.onLine
 
復制代碼 代碼如下:
 
if (navigator.onLine) { //正常工作} else { //執行離線狀態時的任務}
 
這個html5的 navigator的新特性可以很簡單幫我們搞定
HTML5為此定義了一個navigator.onLine屬性,這個屬性值為true表示設備能上網,值為false表示設備離線。
當然不同的瀏覽器,對這個的支持還不太一樣 IE6+和Safari 5+支持的比較好 Firefox 3+和支持navigator.onLine屬性,但你必須手工選中菜單項“文件-Web開發人員(設置)-脫機工作”才能讓瀏覽器正常的工作。
Chrome需要12以上。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM