首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >如何将一个Deferreds数组传递给$ .when()?

如何将一个Deferreds数组传递给$ .when()?

提问于 2017-12-25 16:22:34
回答 2关注 0查看 675

这里是一个例子

HTML:

代码语言:txt
复制
<a href="#">Click me!</a>
代码语言:txt
复制
<div></div>
代码语言:txt
复制
代码语言:txt
复制
JavaScript的:
代码语言:txt
复制
代码语言:txt
复制
function getSomeDeferredStuff() {
代码语言:txt
复制
    var deferreds = [];
代码语言:txt
复制
代码语言:txt
复制
    var i = 1;
代码语言:txt
复制
    for (i = 1; i <= 10; i++) {
代码语言:txt
复制
        var count = i;
代码语言:txt
复制
代码语言:txt
复制
        deferreds.push(
代码语言:txt
复制
        $.post('/echo/html/', {
代码语言:txt
复制
            html: "<p>Task #" + count + " complete.",
代码语言:txt
复制
            delay: count
代码语言:txt
复制
        }).success(function(data) {
代码语言:txt
复制
            $("div").append(data);
代码语言:txt
复制
        }));
代码语言:txt
复制
    }
代码语言:txt
复制
代码语言:txt
复制
    return deferreds;
代码语言:txt
复制
}
代码语言:txt
复制
代码语言:txt
复制
$(function() {
代码语言:txt
复制
    $("a").click(function() {
代码语言:txt
复制
        var deferreds = getSomeDeferredStuff();
代码语言:txt
复制
代码语言:txt
复制
        $.when(deferreds).done(function() {
代码语言:txt
复制
            $("div").append("<p>All done!</p>");
代码语言:txt
复制
        });
代码语言:txt
复制
    });
代码语言:txt
复制
});

我想要“全部完成!” 在所有延迟任务完成后$.when()出现,但似乎不知道如何处理延迟对象数组。“全做完了!” 首先发生,因为该数组不是一个Deferred对象,所以jQuery继续前进,并假设它刚刚完成。

我知道可以将对象传递到函数中,$.when(deferred1, deferred2, ..., deferredX)但是在我试图解决的实际问题中,有多少Deferred对象将被执行。

回答

和开发者交流更多问题细节吧,去 写回答
相关文章

相似问题

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