3.js | |
---|---|
این مثال چگونگی ذخیره سازی اطلاعات توسط مجموعه ای از Model ها را به ما نمایش میدهد. و نشان میدهد چگونه View این عملیات را اجرا میکند. | |
(function($){ | |
Item class: قسمت اصلی Model ما. یک Model پایه که توسط شیء ها در جاوااسکریپت ساخته شده و به وسیله تعدادی تابع کمک کننده رویداد ها را کنترل میکند. | var Item = Backbone.Model.extend({
defaults: {
part1: 'hello',
part2: 'world'
}
});
|
List class: یک مجموعه یا Collection از | 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(){ |
ذخیره کردن مراجع(یا همان خروجی متدها) در | 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); |
|