首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >等待,直到使用$.when()执行所有操作(即使失败)

等待,直到使用$.when()执行所有操作(即使失败)
EN

Stack Overflow用户
提问于 2013-03-09 10:12:22
回答 1查看 851关注 0票数 2

对于jQuery.when(),如果一个请求失败,那么所有请求都会失败。

代码语言:javascript
复制
$.when(deferred1, deferred2).then(function() {
    // Called only after both deferred are resolved
}, function() {
    // Called immediately after one of the deferreds is rejected
});

你怎么能等待所有的东西执行,即使失败呢?我尝试使用.always()而不是.then(),但在第一次失败后也会立即调用回调。

一种(丑陋的)解决方案是使用标志来控制这两个操作何时完成,并在每个操作上使用.always() (不使用$.when())。

代码语言:javascript
复制
var deferred1Complete = false;
var deferred2Complete = false;

function callback() {
    if (deferred1Complete && deferred2Complete) {
        // Execute after both deferred are either resolved or rejected
    }
}

deferred1.always(function() {
    deferred1Complete = true;
    callback();
});

deferred2.always(function() {
    deferred2Complete = true;
    callback();
});

有没有更好的方法来做这件事?

EN

回答 1

Stack Overflow用户

发布于 2013-03-09 12:21:20

另一种解决方案(不是很难看)是链接延迟.always()回调。

代码语言:javascript
复制
deferred1.always(function() {
    deferred2.always(function() {
        // Execute after both deferred are either resolved or rejected
    });
});

我写了一个小函数来处理这个问题:

代码语言:javascript
复制
function whenAlways() {
    var chain = $.extend([], arguments);
    return new $.Deferred(function(deferred) {
        var callback = function() {
            if (chain.length == 0) {
                deferred.resolve();
                return;
            }
            var object = chain.shift();
            $.when(object).always(callback);
        };
        callback();
    }).promise();
}

用法:

代码语言:javascript
复制
whenAlways(deferred1, deferred2)
    .done(function() {
        // Execute after both deferred are either resolved or rejected
    });
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/15306401

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档