检查超时-Ajax之四
有时发出一个请求,后端什么时候返回前端并不清楚。有可能是1秒,3秒甚至更长时间。因此有必要添加一个参数来设置等待的时间,如果在设定的时间内没有返回结果则放弃该次请求。
实现思路:发出请求后指定一个时间,如超过该时间没有返回结果则忽略。window对象的setTimeout方法再次起作用了(setTimeout能解决很多IE下古怪的bug)
代码如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 | var timeout = opt.timeout || 0; //指定是否启用请求超时处理,不传参数timeout则忽略 var isTimeout = false ; //一个标志位,是否超时 if (timeout>0){ setTimeout( function (){ isTimeout = true ; },timeout); } //最后将isTimeout用在onreadystatechange处理中 xhr.onreadystatechange = function (){ if (xhr.readyState == 4 && !isTimeout){ //当请求完成,且没有超时才处理结果 _onStateChange(xhr, type, success, failure); } else {} }; |
调用如下
1 2 3 4 5 | Ajax.text( '../servlet/Ajax' ,{ timeout : 2000, success : function (){}, failure : function (){} }); |
后台我用servlet,直接sleep下即可模拟超时(sleep时间3000大于timeout的设置2000)
1 2 3 4 5 6 7 8 9 10 | try { Thread.sleep( 3000 ); } catch (InterruptedException e) { e.printStackTrace(); } response.setContentType( "text/html" ); PrintWriter out = response.getWriter(); out.println( "request success" ); out.flush(); out.close(); |
请求超时后,success/failure都不会被调用。这样处理有一定的合理性,但缺陷也显而易见,用户不知是超时了还是其它什么错误。下一篇将有所改进。
相关:
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 周边上新:园子的第一款马克杯温暖上架
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?
· 使用C#创建一个MCP客户端