检查超时-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都不会被调用。这样处理有一定的合理性,但缺陷也显而易见,用户不知是超时了还是其它什么错误。下一篇将有所改进。

 

相关:

ajax_04.zip

https://github.com/snandy/io

 

posted on   snandy  阅读(3511)  评论(2编辑  收藏  举报

编辑推荐:
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
阅读排行:
· 周边上新:园子的第一款马克杯温暖上架
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?
· 使用C#创建一个MCP客户端
< 2011年4月 >
27 28 29 30 31 1 2
3 4 5 6 7 8 9
10 11 12 13 14 15 16
17 18 19 20 21 22 23
24 25 26 27 28 29 30
1 2 3 4 5 6 7

统计

点击右上角即可分享
微信分享提示