javascript – Backbone:等待多次获取继续

获取了多个页面的集合,我正在寻找一种方法来了解何时完成所有提取.
这是我的收藏品的样子:
app.collections.Repos = Backbone.Collection.extend({
  model: app.models.Repo,initialize: function(last_page){
    this.url = ('https://api.github.com/users/' + app.current_user + '/watched');

    for (var i = 1; i <= last_page; i++) {
      this.fetch({add: true,data: {page: i}});  
    };
  },...

知道如何用干净的代码实现这一目标吗?

解决方法

使用jQuery deferreds
var deferreds = [];
for (var i = 1; i <= last_page; i++) {
  deferreds.push(this.fetch({add: true,data: {page: i}}));
};

$.when.apply($,deferreds).done(function() {
  ...
  <CODE HERE>
  ...
}

(我实际上没有对此进行测试,但我认为它应该可行.)

when上的jQuery文档:

Provides a way to execute callback functions based on one or more objects,usually Deferred objects that represent asynchronous events.

一个可能有帮助的答案:How do you work with an array of jQuery Deferreds?

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...