I have a simple Backbone model that looks like this:
(function () {
App.Company = Backbone.Model.extend({
defaults: {},
urlRoot: "/Contacts/Companies",
initialize: function () {
var contactPersons = this.get("ContactPersons") || [];
this.set("ContactPersons", new App.ContactPersonCollection(contactPersons));
}
});
})();
Whenever I save the model to the server, the ContactPersons collection is reset to an Array.
Is it really necessary for me to manually turn it into a collection, after a model is saved?
UPDATE: This works as intended — See answer for better approach (IMHO)
(function () {
App.Company = Backbone.Model.extend({
defaults: {},
urlRoot: "/Contacts/Companies",
initialize: function () {
var contactPersons = this.get("ContactPersons") || [];
if (_.isArray(contactPersons)) {
this.set("ContactPersons", new App.ContactPersonCollection(contactPersons));
}
},
parse: function (response) {
if (response.ContactPersons && _.isArray(response.ContactPersons)) {
response.ContactPersons = new App.ContactPersonCollection(response.ContactPersons);
}
return response;
}
});
})();
When you send data back from the server, how are you handling the response? For example if you just send back a [{},{},{}] I don’t think Backbone automatically knows to treat that as a collection. Thus, it sets the
ContactPersonsattribute as what it gets, your vanilla array.What you can do, is override your set function inside your model which will take the array of objects passed in and write to the collection as proper. See this example:
So basically as long as your server response is properly namespaced (response.ContactPersons) then after parsing it will pass your response to the set function. The collection data is treated specially as a collection. Here, I’m just reseting the collection that already exists with the new data. All your other model attributes should continue to be passed on to the original
set().UPDATE – Growing doubt about own answer
I haven’t been able to get this question/answer out of my mind. It certainly works, but I’m becoming unconvinced that using a modified
set()vs. just doing things inparse()is any better. If someone has some comments on the difference between using a modifiedset()vs.parse()with nested models, I’d really welcome the input.