3.js |            |
|---|---|
|                                This example illustrates how to use a Collection of Models to store data, and how to tie changes in those to a View. Working example: 3.html.   |                              |            
               (function($){ |            |
|                                Item class: The atomic part of our Model. A model is basically a Javascript object, i.e. key-value pairs, with some helper functions to handle event triggering, persistence, etc.  |                               var Item = Backbone.Model.extend({
    defaults: {
      part1: 'hello',
      part2: 'world'
    }
  });
   |            
|                                List class: A collection of   |                               var List = Backbone.Collection.extend({
    model: Item
  });
  var ListView = Backbone.View.extend({
    el: $('body'),
    events: {
      'click button#add': 'addItem'
    }, |            
|                                
  |                                 initialize: function(){
      _.bindAll(this, 'render', 'addItem', 'appendItem'); // remember: every function that uses 'this' as the current object should be in here
      this.collection = new List();
      this.collection.bind('add', this.appendItem); // collection event binder
      this.counter = 0;
      this.render();
    },
    render: function(){ |            
|                                Save reference to   |                                   var self = this;
      $(this.el).append("<button id='add'>Add list item</button>");
      $(this.el).append("<ul></ul>");
      _(this.collection.models).each(function(item){ // in case collection is not empty
        self.appendItem(item);
      }, this);
    }, |            
|                                
  |                                 addItem: function(){
      this.counter++;
      var item = new Item();
      item.set({
        part2: item.get('part2') + this.counter // modify item defaults
      });
      this.collection.add(item); // add item to collection; view is updated via event 'add'
    }, |            
|                                
  |                                 appendItem: function(item){
      $('ul', this.el).append("<li>"+item.get('part1')+" "+item.get('part2')+"</li>");
    }
  });
  var listView = new ListView();
})(jQuery); |            
                              ![]() Follow me on Twitter: @r2r  
              |                              |