ajax done fail都执行,关于jQuery deferred 多个AJAX执行问题

我写了两个函数,分别是使用AJAX请求数据,为了能控制他们的执行顺序,也不想改变AJAX的异步开关,发现使用deferred写法后,fail和done方法都执行了

代码:

function func1(dfd) {

$.ajax({

type: "POST",

timeout: 10 * 1000,

contentType: "application/x-www-form-urlencoded; charset=utf-8",

data: { },

url: ""

}).done(function (msg) {

dfd.resolve();

}).fail(function (XMLHttpRequest, textStatus, errorThrown) {

dfd.reject();

});

}

return dfd;

}

function func2() {

$.ajax({

type: "POST",

timeout: 5 * 1000,

contentType: "application/x-www-form-urlencoded; charset=utf-8",

data: { },

url: ""

}).done(function (msg) {

}

}).fail(function (XMLHttpRequest, textStatus, errorThrown) {

console.log(XMLHttpRequest.status + "|" + XMLHttpRequest.statusText);

});

}

$(document).ready(function () {

var defer = new $.Deferred();

$.when(fucn1(defer)).done(func2()).fail(function () { alert("fail") });

});

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值