8

我获取多个页面的集合,我正在寻找一种方法来了解所有获取何时完成。这是我的收藏的样子:

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}});  
    };
  }, ...

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

4

2 回答 2

14

使用 jQuery延迟

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>
  ...
}

(我还没有实际测试过,但我认为它应该可以工作。)

jQuery 文档when

提供一种基于一个或多个对象(通常是表示异步事件的延迟对象)执行回调函数的方法。

另一个可能有帮助的答案:你如何使用 jQuery Deferreds 数组?

于 2012-08-23T03:49:00.780 回答
2

一种选择是使用underscore.js' after-function ( docs ),但这需要使用 success -callback,因为会有很多 add -events:

initialize: function(last_page){
  this.url = ('https://api.github.com/users/' + app.current_user + '/watched');

  var self = this; // save a reference to this

  var successCallback = _.after(function() {

    self.trigger('allPagesFetched'); //trigger event to notify all listeners that fetches are done

  }, last_page); // this function will be called when it has been called last_page times

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

希望这有帮助!

于 2012-08-23T05:46:40.000 回答