This question has been asked several times, but none of the solutions offered are working for me.
In this Backbone collection, how can I access and loop through its models?
I've tried several ways in the code below; includes additions based on Mark V.'s answer.
Code is also available here: http://jsfiddle.net/LPbsP/3/
(function() {
console.log(Backbone);
window.App = {
Model: {},
Collection: {},
View: {}
};
App.Model.Whatever = Backbone.Model.extend({});
App.Collection.Whatever = Backbone.Collection.extend({
model: App.Model.Whatever,
initialize: function(models, options) {
this.getModels();
_.bindAll(this, 'getModelsWithBindAll');
this.getModelsWithBindAll();
console.log(this);
console.log(models);
models.each(function(model) {
console.log(model);
});
},
getModels: function() {
console.log('in getModels');
console.log(this);
whateverCollection.each(function(model) {
console.log(model);
console.log(model.toJSON());
});
},
getModelsWithBindAll: function() {
console.log('in getModelsWithBindAll');
console.log(this);
whateverCollection.each(function(model) {
console.log(model);
console.log(model.toJSON());
});
}
});
var whateverCollection = new App.Collection.Whatever([
{
name: 'jim',
title: 'boss'
},
{
name: 'tom',
title: 'worker'
}
]);
console.log('program code');
console.log(whateverCollection);
})();
Results:
Object (Backbone)
in getModels
r (length: 0, models: Array[0] ... )
Cannot call method 'each' of undefined
Here are the other questions I referenced: