做了一个功能,涉及前端访问后端代码,后端代码涉及到访问其他服务器的功能。当后端访问其他服务器超时时,前端需要做一下超时操作,代码如下:
function ajaxSetTimeout(){
$.ajax({
type: "post",
contentType: "application/json;charset=utf-8",
url: "http://localhost:8080/test", //本地服务器
dataType: "json",
timeout: 3000,//设置超时时间,超过3秒后执行complete中的操作
success: function (data) {
//后台返回操作
},
complete: function (XMLHttpRequest, status) { //无论如何都会执行complete
console.info("complete=====>");
if (status == 'timeout') {//超时,status还有success,error等值的情况
alert("访问超时");
}
}
});
}
!!注意:使用timeout的同时,不能使用async的同步属性,原因从网上查了一下:同步操作会将浏览器行为全部阻止,直至有同步请求有响应为止
所以两者是有冲突的。