用過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"); }
