ajax异步判断网站是否可以访问到的解决方法

 
Js代码
  1. function getXMLHttpRequest(){   
  2.   var client = getXMLHttpRequestFromIE();   
  3.    if(client == null){   
  4.         client = new XMLHttpRequest();   
  5.    }   
  6.   return client;   
  7. }   
  8.   
  9. function getXMLHttpRequestFromIE(){   
  10.   var namePrefixes = ["Msxml3","Msxml2","Msxml","Microsoft"];   
  11.   for(var i = 0; i < namePrefixes.length; i++){   
  12.        try{   
  13.            var name = namePrefixes[i] + ".XMLHTTP";   
  14.            return new ActiveXObject(name);   
  15.        }catch(e){   
  16.        }   
  17.   }   
  18.   return null;   
  19. }   
  20. var client = null;   
  21. //是否可以访问   
  22. var isRun = false;   
  23. //返回值   
  24. var stateString="";   
  25. //请求url的网站   
  26. function connUrl(url){   
  27.     client = getXMLHttpRequest();   
  28.     var actionURL = convertURL(url);   
  29.     try{   
  30.         client.open("GET", actionURL, true);   
  31.         client.onreadystatechange = callBack;   
  32.         client.send(null);   
  33.     }catch(e){}   
  34.     finally{   
  35.     }   
  36. }   
  37. function callBack(){   
  38.     if(client.readyState == 4){   
  39.         stateString = client.responseText;   
  40.         if(stateString && client.status==200)   
  41.             isRun = true;   
  42.     }   
  43. }   
  44. //是否可达   
  45. function isReach(url){   
  46.     connUrl(url);   
  47.     return isRun;   
  48. }   
  49. //给url地址增加时间戳,骗过浏览器,不读取缓存       
  50. function convertURL(url) {       
  51.         //获取时间戳       
  52.         var timstamp = (new Date()).valueOf();       
  53.         //将时间戳信息拼接到url上   
  54.         if (url.indexOf("?") >= 0) {       
  55.                 url = url + "&t=" + timstamp;       
  56.         } else {       
  57.                 url = url + "?t=" + timstamp;       
  58.         }       
  59.         return url;       
  60. }   
  61. //因为是异步,先调用,此时isRun的值是false   
  62. isReach("http://www.baidu.com");   
  63. //3秒钟后判断isRun的值,如果为false认为网站不可达,类似超时时间   
  64. setTimeout(function(){      
  65.         //alert(stateString);    
  66.         //alert(isRun);   
  67.         if(isRun==true){   
  68.             document.getElementById("ceshi").innerText = "网站是通的!";   
  69.         }else{   
  70.             document.getElementById("ceshi").innerText = "网站不通!";   
  71.         }   
  72.     },3000);  

 

Html代码
  1. <div id="ceshi"></div>  
<div id="ceshi"></div>

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值