首页 > 代码库 > 利用setTimeoutc处理javascript ajax请求超时
利用setTimeoutc处理javascript ajax请求超时
用过jquery的人都知道里面的$.ajax能设置超时处理及各种错误的抛出,确实好用。原生的js没有对应的方法,还得写各种兼容。在实际运用中,不管请求是否成功都应该做容错处理,
不然用户不知道到底发生了什么,体验非常不好。超时就是一种情况,不可能请求失败了还让用户在那傻傻等待,是谁都受不了。下面就介绍一下用setTimeout来实现请求的超时处理。
function createXMLHttpRequest() { var request = false; if(window.XMLHttpRequest) { request = new XMLHttpRequest(); if(request.overrideMimeType) { request.overrideMimeType(‘text/xml‘); } } else if(window.ActiveXObject) { var versions = [‘Microsoft.XMLHTTP‘, ‘MSXML.XMLHTTP‘, ‘Microsoft.XMLHTTP‘,‘Msxml2.XMLHTTP.7.0‘, ‘Msxml2.XMLHTTP.6.0‘, ‘Msxml2.XMLHTTP.5.0‘,‘Msxml2.XMLHTTP.4.0‘, ‘MSXML2.XMLHTTP.3.0‘, ‘MSXML2.XMLHTTP‘]; for(var i=0; i<versions.length; i++) { try { request = new ActiveXObject(versions[i]); if(request) { return request; } } catch(e) {} } } return request;}function ajax(xmlhttp,_method, _url, _param, _callback) { if (typeof xmlhttp == ‘undefined‘) return; xmlhttp.onreadystatechange = function() { if (xmlhttp.readyState==4 && xmlhttp.status==200) { _callback(xmlhttp); } } xmlhttp.open(_method, _url, true); if (_method == "POST") { xmlhttp.setRequestHeader("Content-Type", "application/x-www-form-urlencoded"); xmlhttp.setRequestHeader("Content-Length", _param.length); xmlhttp.send(_param); } else { xmlhttp.send(null); }}
//使用举例var xmlhttp = createXMLHttpRequest();var t1; //用来作超时处理function adduserok(request) { alert(request.responseText); if (t1) clearTimeout(t1);}function connecttoFail() { if (xmlhttp) xmlhttp.abort(); alert (‘Time out‘);}if (xmlhttp) { ajax(xmlhttp,"POST", "http://10.1.2.187/adduser.cgi","act=do&user=abc",adduserok); t1 = setTimeout(connecttoFail,30000);}else { alert ("Init xmlhttprequest fail");}
利用setTimeoutc处理javascript ajax请求超时
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。