先给大家分析下超时原因:
1.网络不通畅。
2.后台运行比较慢(服务器第一次运行时,容易出现)
超时结果:JQ中 timeout设置请求超时时间。
如果服务器响应时间超过了 设置的时间,则进入 ERROR (错误处理)
超时解决方案:
1.默认的timeout为0,代表永不超时
2.尽量把timeout设置的大一点。坏处:使数据的加载变慢(貌似。呵呵)。
3.在ERROR回调函数中写 有关于 超时 处理 的函数:例如,可以在超时的情况下再次调用取数据函数。
——————————————————- ——————————————————-
这个ajax 里有个success的函数. 是成功是返回的 还有个好像是叫error的返回函数
如果请求失败的时候 会触发这个函数.
我觉得你可以在error里处理.
如果执行了这个函数那你就调用你第二个ajax方法呗.
jQuery和ExtJS的timeOut超时设置和event事件处理 .
jQuery和ExtJS的timeOut超时设置和event事件处理 .
ajax请求如何自定义超时时间,并处理相应的超时事件呢?
对jQuery 来说,超时可以直接设置timeout参数,并在error事件中捕获第二个参数,如果是“timeout”则表明捕获了超时事件,非常清楚。
例子:
$.ajax({
type: "POST"
,
contentType: "application/json"
,
url: "../ws/MyService.asmx/test"
,
data: '{"email":"'
+email+'"}'
,
timeout: 30000, //超时时间:30秒
dataType: 'json'
,
error: function
(XMLHttpRequest, textStatus, errorThrown){
//TODO: 处理status, http status code,超时 408
// 注意:如果发生了错误,错误信息(第二个参数)除了得到null之外,还可能
//是"timeout", "error", "notmodified" 和 "parsererror"。
},
success: function
(result) {
// TODO: check result
}
}); 另外,error事件返回的第一个参数XMLHttpRequest有一些有用的信息:
XMLHttpRequest.readyState: 状态码
0 - (未初始化)还没有调用send()方法
1 - (载入)已调用send()方法,正在发送请求
2 - (载入完成)send()方法执行完成,已经接收到全部响应内容
3 - (交互)正在解析响应内容
4 - (完成)响应内容解析完成,可以在客户端调用了
XMLHttpRequest.status属性:一些错误代码
HTTP
1xx-信息提示
这些状态代码表示临时的响应。客户端在收到常规响应之前,应准备接收一个或多个1xx响应。
100-继续。
101-切换协议。
2xx-成功
这类状态代码表明服务器成功地接受了客户端请求。










