Pobierze kolekcję wielu stron i szukam sposobu, aby wiedzieć, kiedy skończy się wszystkie pobieranie. Oto, jak wygląda moja kolekcja:

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

Jakikolwiek pomysł, jak mogłem to osiągnąć za pomocą czystego kodu?

8
Gregory 23 sierpień 2012, 07:33

1 odpowiedź

Jedną z opcji jest użycie underscore.js 'after -Function (Docs), ale to Wymaga wykorzystania sukcesu -Callback, ponieważ będzie dużo dodatków:

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

Mam nadzieję, że to pomogło!

2
jakee 23 sierpień 2012, 05:46