javascript檢測(cè)是否聯(lián)網(wǎng)的實(shí)現(xiàn)代碼
最簡(jiǎ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變量來(lái)檢測(cè)是否聯(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ò)資源的問(wèn)題就是檢測(cè)的互聯(lián)網(wǎng),如果是局域網(wǎng)檢測(cè)是無(wú)能為力了。
這時(shí)候需要一個(gè)更好的解決方案,就要用到navigator.onLine,這個(gè)屬性比較坑的就是瀏覽器兼容,chrome、Safari 都完美支持,IE7以上是支持的?;鸷虸E6比較坑,只有在瀏覽器“脫機(jī)狀態(tài)”下才返回false,其他都返回true。掐了網(wǎng)線都是true,Opera直接不支持了。
所以還得加一個(gè)兼容方法:給location.hostname地址發(fā)一個(gè)http頭請(qǐng)求,代碼如下:
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;
}
里面一個(gè)要注意的就是open方法的第三個(gè)參數(shù)要傳false,必須是同步請(qǐng)求。
總結(jié):支持navigator.onLine的瀏覽器就用navigator.onLine,不支持的就發(fā)一個(gè)http頭請(qǐng)求。
原創(chuàng)文章,轉(zhuǎn)載請(qǐng)注明: 轉(zhuǎn)載自前端開(kāi)發(fā)
- js實(shí)現(xiàn)雙向鏈表互聯(lián)網(wǎng)機(jī)頂盒實(shí)戰(zhàn)應(yīng)用實(shí)現(xiàn)
- android判斷phonegap是否聯(lián)網(wǎng)且加載super.loadUrl網(wǎng)址
- javascript判斷機(jī)器是否聯(lián)網(wǎng)的2種方法
- Android中判斷手機(jī)是否聯(lián)網(wǎng)實(shí)例
- php銀聯(lián)網(wǎng)頁(yè)支付實(shí)現(xiàn)方法
- 通過(guò)JS判斷聯(lián)網(wǎng)類型和連接狀態(tài)的實(shí)現(xiàn)代碼
- Android中判斷是否聯(lián)網(wǎng)實(shí)現(xiàn)代碼
- Android互聯(lián)網(wǎng)訪問(wèn)圖片并在客戶端顯示的方法
- Android sdcard實(shí)現(xiàn)圖片存儲(chǔ) 、聯(lián)網(wǎng)下載
- 如何判斷軟件程序是否聯(lián)網(wǎng) 聯(lián)網(wǎng)狀態(tài)提示信息Android實(shí)現(xiàn)
相關(guān)文章
Javascript實(shí)現(xiàn)圖片輪播效果(一)讓圖片跳動(dòng)起來(lái)
圖片輪播效果,在各大網(wǎng)站的首頁(yè)都能看到,比較常見(jiàn),下面腳本之家小編給大家介紹Javascript實(shí)現(xiàn)圖片輪播效果(一)讓圖片跳動(dòng)起來(lái),需要的朋友參考下2016-02-02
js字符串去重復(fù)id的實(shí)現(xiàn)代碼
最近由于需要我們將相關(guān)id的重復(fù)的去掉,一個(gè)是客戶端一個(gè)后臺(tái)程序把關(guān),這里分享下js的去重復(fù)id的實(shí)現(xiàn)代碼2013-07-07
javascript實(shí)現(xiàn)獲取圖片大小及圖片等比縮放的方法
這篇文章主要介紹了javascript實(shí)現(xiàn)獲取圖片大小及圖片等比縮放的方法,涉及javascript針對(duì)圖形圖像相關(guān)屬性獲取與修改相關(guān)操作技巧,需要的朋友可以參考下2016-11-11

