我开始用这个简单的例子学习Backbone:
<div id="counter">unkown</div>
<button id="add-button">ADD</button>
(function($){
var Counter = Backbone.Model.extend({
defaults: {
count: 0
}
});
var CounterView = Backbone.View.extend({
el: "#counter",
events: {
"click #add-button": "add"
},
add: function() {
this.model.count++;
render();
},
render: function() {
$(this.el).text(this.model.get("count"));
return this;
},
initialize: function(){
this.render();
}
});
var counterItem = new Counter();
var counterView = new CounterView({model: counterItem});
}(jQuery)); // function($)
Run Code Online (Sandbox Code Playgroud)
因此,当按下"添加"按钮时,计数器应该增加,视图应该更新.我已经绑定了视图和模型,并将click事件与add函数链接,但不知怎的,这不起作用.
所以我想我做错了什么或者我只是缺少一些约束力?
编辑:修正了建议...仍然无法正常工作:
<div class="list">
<div id="counter">unkown</div>
<button id="add-button">ADD</button>
</div>
(function($){
var Counter = Backbone.Model.extend({
defaults: {
count: 0
}
});
var CounterView = Backbone.View.extend({
el: "#counter",
events: {
"click #add-button": "add"
},
add: function() {
alert("ADD");
this.model.set("count", this.model.get("count") + 1);
this.render();
},
render: function() {
$(this.el).text(this.model.get("count"));
return this;
},
initialize: function(){
this.render();
}
});
var counterItem = new Counter();
var counterView = new CounterView({model: counterItem});
}(jQuery)); // function($)
Run Code Online (Sandbox Code Playgroud)
编辑:固定和工作
<div id="counterHolder">
<div id="counter">
<span>unknown</span>
<button id="add-button">ADD</button>
</div>
</div>
<script>
(function($){
var Counter = Backbone.Model.extend({
defaults: {
count: 0
},
increase: function(){
this.set("count", this.get("count") + 1);
}
});
var CounterView = Backbone.View.extend({
el: "#counter",
events: {
"click #add-button": "add"
},
add: function() {
this.model.increase();
},
render: function() {
$("#counter span").text(this.model.get("count"));
return this;
},
initialize: function(){
this.render = _.bind(this.render, this);
this.render();
this.model.bind('change:count', this.render);
}
});
var counterItem = new Counter();
var counterView = new CounterView({model: counterItem});
}(jQuery)); // function($)
</script>
Run Code Online (Sandbox Code Playgroud)
该按钮必须是视图的后代 el
像下面更新您的HTML,它应该工作
<div id="counter">
<button id="add-button">ADD</button>
</div>
Run Code Online (Sandbox Code Playgroud)
如果您仍想显示计数,请添加其他内容 span
<div id="counter">
<span id="count" />
<button id="add-button">ADD</button>
</div>
Run Code Online (Sandbox Code Playgroud)
并更新您的渲染方法
render: function() {
this.$('#count').text(this.model.get("count"));
return this;
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
3396 次 |
| 最近记录: |