做了一个功能,涉及前端访问后端代码,后端代码涉及到访问其他服务器的功能。当后端访问其他服务器超时时,前端需要做一下超时操作,代码如下:
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的同步属性,原因从网上查了一下:同步操作会将浏览器行为全部阻止,直至有同步请求有响应为止
所以两者是有冲突的。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/158171.html