用过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"); }
时间: 2024-11-03 16:16:21