gpt4 book ai didi

javascript - Backbone.js 如何连接 View 和 Model

转载 作者:可可西里 更新时间:2023-11-01 02:32:24 25 4
gpt4 key购买 nike

我正在尝试通过以下示例学习 backbone.js。然后卡在了点上

ItemView = Backbone.View.extend

为什么可以使用this.model.get?我认为这是指将要创建的 ItemView 实例。那为什么 ItemView 会有模型属性呢?!!

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

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


var ItemView = Backbone.View.extend({

tagName: 'li',
initialize: function(){
_.bindAll(this, 'render');
},
render: function(){
$(this.el).html('<span>'+this.model.get('part1')+' '+this.model.get('part2')+'</span>');
return this;
}
});

var ListView = Backbone.View.extend({
el: $('body'),
events: {
'click button#add': 'addItem'
},
initialize: function(){
_.bindAll(this, 'render', 'addItem', 'appendItem');

this.collection = new List();
this.collection.bind('add', this.appendItem);

this.counter = 0;
this.render();
},
render: function(){
$(this.el).append("<button id='add'>Add list item</button>");
$(this.el).append("<ul></ul>");
_(this.collection.models).each(function(item){
appendItem(item);
}, this);
},
addItem: function(){
this.counter++;
var item = new Item();
item.set({
part2: item.get('part2') + this.counter
});
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);

最佳答案

模型通常像这样作为构造函数参数传递给 View 。

var item = new Item();
var view = new ItemView({ model : item });

也可以传递其他参数,查看文档 http://backbonejs.org/#View .

关于javascript - Backbone.js 如何连接 View 和 Model,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6784635/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com