怎样将ajax嵌套在循环,在循环中对嵌套的ajax调用使用$ .Deferred()

我花了太多时间寻找类似的问题并尝试解决方案,所以我希望有人能找到解决方案。

基本上,我想在函数a()完成时收到通知。问题在于该函数包含一个ajax调用和一个调用b()的循环,后者又包含一个ajax调用。

像这样:

// called by main()

function a() {

return $.ajax("http://url1").pipe(function(data){

for (var i = 0; i < 2; i++) {

console.log('a called');

b();

}

});

}

// called by a()

function b() {

for (var i = 0; i < 2; i++) {

$.ajax("http://url2", function(data){

// do something

console.log('b called');

}

}

}

function main(){

$.when(a()).done(function(){

console.log('all completed');

});

}

然后,我希望看到的是,可能同时在顶部都调用了a():

a called

b called

b called

a called

b called

b called

all completed

相反,我得到了

a called

all completed

b called

b called

或其一些变体。

我知道上面的代码在循环和b()中都缺少延迟功能。在我尝试过的某些变体中,从未调用main()中的done()处理函数。

有人知道怎么做吗?

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值