IE8+中XMLHttpRequest支持timeout属性及ontimeout事件
不久前我写了一个Ajax工具库。这篇是对请求超时处理的补充。IE8/9的XMLHttpRequest对象已经增加这方面的支持了。IE10 pre1测试也支持。如果W3C能将这两个东东标准化多好啊,不用那么的hack方式实现了。
XMLHttpRequest的timeout属性可以设置,表示在等待响应多少毫秒之后终止。
即如果在规定的时间内浏览器没有收到响应,那么就触发timeout事件,给xhr.ontimeout赋值为一个响应函数后可被执行。
主要代码如下
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 | xhr.onreadystatechange = function (){ if (xhr.readyState == 4){ try { var s = xhr.status; if (s>= 200 && s < 300){ //success(xhr); } else { //failure(xhr); } } catch (e){} } else {} }; xhr.open(); xhr.timeout = 1000; xhr.ontimeout = function (){ alert( 'request timeout' ); } |
超时后再访问xhr的status属性会出异常,因此加上try catch。
相关:
http://msdn.microsoft.com/en-us/library/ms535874%28VS.85%29.aspx
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步