javascript檢測是否聯(lián)網(wǎng)的實現(xiàn)代碼
最簡單粗暴的方式就是加載網(wǎng)絡(luò)資源,JS文件或者圖片文件。
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.10.2/jquery.min.js"></script>
typeof window.jQuery === "undefined" // return false or ture
用jQuery變量來檢測是否聯(lián)網(wǎng)
function doConnectFunction() { return true; } function doNotConnectFunction() { return false; } var i = new Image(); i.onload = doConnectFunction; i.onerror = doNotConnectFunction; i.src = 'http://su.bdimg.com/static/superplus/img/logo_white.png?d=' + escape(Date());
加載網(wǎng)絡(luò)資源的問題就是檢測的互聯(lián)網(wǎng),如果是局域網(wǎng)檢測是無能為力了。
這時候需要一個更好的解決方案,就要用到navigator.onLine,這個屬性比較坑的就是瀏覽器兼容,chrome、Safari 都完美支持,IE7以上是支持的?;鸷虸E6比較坑,只有在瀏覽器“脫機狀態(tài)”下才返回false,其他都返回true。掐了網(wǎng)線都是true,Opera直接不支持了。
所以還得加一個兼容方法:給location.hostname地址發(fā)一個http頭請求,代碼如下:
var xhr = new ( window.ActiveXObject || XMLHttpRequest )( "Microsoft.XMLHTTP" ); var status; xhr.open( "HEAD", "http://" + window.location.hostname + "/?rand=" + Math.floor((1 + Math.random()) * 0x10000), false ); try { xhr.send(); return ( xhr.status >= 200 && xhr.status < 300 || xhr.status === 304 ); } catch (error) { return false; }
里面一個要注意的就是open方法的第三個參數(shù)要傳false,必須是同步請求。
總結(jié):支持navigator.onLine的瀏覽器就用navigator.onLine,不支持的就發(fā)一個http頭請求。
原創(chuàng)文章,轉(zhuǎn)載請注明: 轉(zhuǎn)載自前端開發(fā)
- js實現(xiàn)雙向鏈表互聯(lián)網(wǎng)機頂盒實戰(zhàn)應(yīng)用實現(xiàn)
- android判斷phonegap是否聯(lián)網(wǎng)且加載super.loadUrl網(wǎng)址
- javascript判斷機器是否聯(lián)網(wǎng)的2種方法
- Android中判斷手機是否聯(lián)網(wǎng)實例
- php銀聯(lián)網(wǎng)頁支付實現(xiàn)方法
- 通過JS判斷聯(lián)網(wǎng)類型和連接狀態(tài)的實現(xiàn)代碼
- Android中判斷是否聯(lián)網(wǎng)實現(xiàn)代碼
- Android互聯(lián)網(wǎng)訪問圖片并在客戶端顯示的方法
- Android sdcard實現(xiàn)圖片存儲 、聯(lián)網(wǎng)下載
- 如何判斷軟件程序是否聯(lián)網(wǎng) 聯(lián)網(wǎng)狀態(tài)提示信息Android實現(xiàn)
相關(guān)文章
淺析BootStrap模態(tài)框的使用(經(jīng)典)
Bootstrap Modals(模態(tài)框)是使用定制的 Jquery 插件創(chuàng)建的。本文給大家介紹BootStrap模態(tài)框的使用,感興趣的朋友一起學(xué)習(xí)吧2016-04-04從零開始用electron手?jǐn)]一個截屏工具的示例代碼
這篇文章主要介紹了從零開始用electron手?jǐn)]一個截屏工具的示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-10-10基于JavaScript實現(xiàn)簡單的音樂音譜圖效果
我們經(jīng)??吹皆诼牁芬舻臅r候,會有音譜圖隨著音樂的節(jié)奏不斷變化給人視覺上的享受,那么本文我們就來通過JavaScript來實現(xiàn)這一效果,感興趣的可以了解下2023-11-11JS中Map、WeakMap和Object的區(qū)別解析
Map、WeakMap和Object都是JavaScript中用于存儲鍵值對的數(shù)據(jù)結(jié)構(gòu),它們在鍵類型、垃圾回收、可枚舉性、方法和操作、以及繼承等方面存在一些區(qū)別,適用于不同的場景,本文給大家詳細(xì)講解js map、weakmap和object區(qū)別,需要的朋友可以參考下2023-04-04使用Browserify來實現(xiàn)CommonJS的瀏覽器加載方法
下面小編就為大家?guī)硪黄褂肂rowserify來實現(xiàn)CommonJS的瀏覽器加載方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-05-05百度Popup.js彈出框進化版 拖拽小框架發(fā)布 兼容IE6/7/8,Firefox,Chrome
百度空間的彈出窗口和拖拽效果(也就是popup.js),代碼精簡,效果也很好,我們可以在很多大型網(wǎng)站上見到這種效果,在我的項目中也使用了該js。2010-04-04