برو به …

3.js

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

نمونه اجرا شده
رفتن به مرحله بعدی

(function($){

Item class: قسمت اصلی Model ما. یک Model پایه که توسط شیء ها در جاوااسکریپت ساخته شده و به وسیله تعدادی تابع کمک کننده رویداد ها را کنترل میکند.

  var Item = Backbone.Model.extend({
    defaults: {
      part1: 'hello',
      part2: 'world'
    }
  });      
  

List class: یک مجموعه یا Collection از Itemها. یک آرایه پایه به همراه تعدادی تابع کمک کننده.

  var List = Backbone.Collection.extend({
    model: Item
  });

  var ListView = Backbone.View.extend({
    el: $('body'),
    events: {
      'click button#add': 'addItem'
    },

initialize(): یک نمونه از Collection, که مسئول اضاف کردن رویداد add برای متد appendItem() است. (تاکید میکنم که Backbonejs توان ارتباط جداگانه و کنترل جداگانه رویدادها را ندارد...).

    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(){

ذخیره کردن مراجع(یا همان خروجی متدها) در this که پس از دسترسی به آن، واکنش ها را در آن اعمال میکند.

      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(): رد و بدل کردن اطلاعات بین View .Collection/model پس از بروزرسانی آن را به اضاف کردن یک شنونده رویداد به appendItem() موکول میکند.(یعنی غالبا خروجی بروزرسانی را در این متد پیکر بندی میکند.)

    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(): این متد باعث ایجاد رویداد اضاف کردن, و کنترل کننده بروزرسانی های بصری میشود که همان خروجی اصلی به حساب می آید. (نسخه پیکربندی شده ی addItem())

    appendItem: function(item){
      $('ul', this.el).append("<li>"+item.get('part1')+" "+item.get('part2')+"</li>");
    }
  });

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