I have written a model/view/collection using Backbone.js. My collection uses the fetch method to load the models from a remote server. The url required for this collection needs an id like: messages/{id}. But I have found no clean way to pass options to the Collection.
The backbone.js view accepts options by passing it on construction: view([options]), but the collection expects a list of models upon construction: collection([models]).
What is the "cleanest" way of passing parameters/options to this collection?
Shortened code:
var Messages = Backbone.Collection.extend({
model: Message,
url: 'http://url/messages/' + id
});
The way you have the url property declared, the value will be determined once when the browser initially loads the javascript file, and 'id' will be undefined.
The Backbone.Collection accepts options as the second argument in its constructor, so you can pass the id value as an option, and then set the url value within the initialize function of the collection.
Here's an example
@Paul's answer is good, but it's also worth noting that the
url
attribute can be a function. In my opinion (and it's just opinion, since the end result is the same), the code is a little more legible, if more verbose, if you set the id ininitialize
and the reference it in a function:Just to make sure, though - you aren't confusing the
id
here with the Modelid
, are you? @Paul's answer, and my code above, assume that you have multipleMessages
collections, each with its own id. If the API path/messages/<id>
actually refers to a message, not a set of messages, then you only need to set theurl
to/messages/
in the Collection, and Backbone will automatically use/messages/<id>
for each model.