【发布时间】:2015-01-19 21:07:26
【问题描述】:
我有一系列 Backbone 模型。我想将模型属性设置为“活动”,但要确保一次只能活动 1 个模型。我无法让它工作,正在寻找一些指导。
这是我的代码:http://jsfiddle.net/doen1mm9/
这是我的 JavaScript 和模板。
JS:
var data = [
{
"color": "blue",
"name": "Johnny"
},
{
"color": "green",
"name": "Melissa"
},
{
"color": "yellow",
"name": "Bill"
}
];
var TheModel = Backbone.Model.extend({
});
var TheCollection = Backbone.Collection.extend({
model: TheModel,
initialize: function() {
this.on('change:isActive', this.ensureSingleActive, this);
},
ensureSingleActive: function(current) {
var previous = this.findWhere({isActive: true});
if (previous !== undefined) {
previous.set('isActive', false);
}
current.set('isActive', true);
}
});
var ListView = Backbone.View.extend({
el: '.js-container',
tagName: 'ul',
render: function() {
this.collection.each(function(item) {
var listItemView = new ListItemView({model: item});
this.$el.append(listItemView.el);
}, this);
}
});
var ListItemView = Backbone.View.extend({
initialize: function() {
this.listenTo(this.model, 'change', this.render);
this.render();
},
tagName: 'li',
template: _.template( $('#item-template').html() ),
render: function() {
var temp = this.template({model: this.model.toJSON()});
this.$el.html( temp );
},
events: {
'click': 'toggleActive'
},
toggleActive: function(e) {
this.model.set('isActive');
console.log(this.model.toJSON());
}
});
var theCollection = new TheCollection(data);
var listView = new ListView({collection: theCollection});
listView.render();
模板:
<div class="js-container"></div>
<script type="text/template" id="item-template">
<span <% if (model.isActive === true) { %> class="active" <% } %>>
<%- model.name %>
</span>
</script>
【问题讨论】:
标签: javascript jquery backbone.js