برو به …

5.js

این مثال نشان میدهد که چگونه دو Model جدید آیتم های خروجی را تغییر میدهند و پاک میکنند, و نشان میدهد چگونه چنین عملی در View مربوط به Model انجام میپذیرد.

نمونه اجرا شده

(function($){

Backbone.sync: عملکرد ذخیره سازی مداوم و بیهوده را لغو میکند. که به وسیله Model.destroy() کار خواهد کرد بدون هیچ خطایی.

  Backbone.sync = function(method, model, success, error){ 
    success();
  }
  
  var Item = Backbone.Model.extend({
    defaults: {
      part1: 'hello',
      part2: 'world'
    }
  });
  
  var List = Backbone.Collection.extend({
    model: Item
  });

  var ItemView = Backbone.View.extend({
    tagName: 'li', // name of tag to be created        

ItemViewها به 2 عمل پاسخ نشان خواهند داد،: تغییر و حذف.

    events: { 
      'click span.swap':  'swap',
      'click span.delete': 'remove'
    },    

initialize() اتصالات Model را برقرار میکند تا بر حذف شدن و تغییر کردن کنترل داشته باشند.

    initialize: function(){
      _.bindAll(this, 'render', 'unrender', 'swap', 'remove'); // every function that uses 'this' as the current object should be in here

      this.model.bind('change', this.render);
      this.model.bind('remove', this.unrender);
    },

render() نصب و پایه گذاری تگ های span که به عمل های حذف و تغییر مربوط هستند.

    render: function(){
      $(this.el).html('<span style="color:black;">'+this.model.get('part1')+' '+this.model.get('part2')+'</span> &nbsp; &nbsp; <span class="swap" style="font-family:sans-serif; color:blue; cursor:pointer;">[swap]</span> <span class="delete" style="cursor:pointer; color:red; font-family:sans-serif;">[delete]</span>');
      return this; // for chainable calls, like .render().el
    },

unrender(): آیتم ها را از DOM یا همان محتویات صفحه حذف میکند.

    unrender: function(){
      $(this.el).remove();
    },

swap(): یک آیتم را از سر مشخصه های او، تغییر میدهد. زمانی که set() فراخوانده میشود, تغییرات انجام میپذیرد.

    swap: function(){
      var swapped = {
        part1: this.model.get('part2'), 
        part2: this.model.get('part1')
      };
      this.model.set(swapped);
    },

remove(): در این متد ما از destroy() برای حذف یک مدل از Collection استفاده میکنیم. به طور معمول از این متد برای حذف اطلاعات استفاده خواهید کرد.

    remove: function(){
      this.model.destroy();
    }
  });
  

زیرا ویژگی های ذاتی(تغییر و حذف) برای هر یک از آیتم ها, دیگر نیازی به تغییر ListView ندارند.

  var ListView = Backbone.View.extend({
    el: $('body'), // el attaches to existing element
    events: {
      'click button#add': 'addItem'
    },
    initialize: function(){
      _.bindAll(this, 'render', 'addItem', 'appendItem'); // 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(){
      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);
    },
    appendItem: function(item){
      var itemView = new ItemView({
        model: item
      });
      $('ul', this.el).append(itemView.render().el);
    }
  });

  var listView = new ListView();
})(jQuery);
@usablica - @ar2r :در توییتر دنبال کنید