我有一个相当通用的模型,并且正在收集该模型(请参见下文),作为一系列观点的基础。在多个视图上,选择其中一个模型会生成操作(通过“ selected”属性),我需要能够仅在客户端跟踪选择。
但是,似乎在Backbone中没有干净的方法可以做到这一点。在客户端模型上添加/更改的所有属性都将同步到服务器。更改该属性时不能使用{silent : yes}
,因为当在该属性上触发change
事件时,我需要触发视图中的更改。我想出的唯一方法是覆盖save
上的Backbone.Model
函数
我的问题:有没有办法让我缺少客户端唯一的属性,或者我的方法是否在某种程度上存在结构性缺陷,而我只是没有看到?
var CSEvent = Backbone.Model.extend({
idAttribute: "_id",
urlRoot : '/api/events',
defaults: {
title : "",
type : "Native",
repeatOrOneTime : "OneTime",
selected : false
}
});
var CSEventCollection = Backbone.Collection.extend({
model: CSEvent,
url: '/api/events',
getSelectedEvent : function() {
return this.find(function(csevent) { return csevent.get('selected') === true; });
},
selectEvent : function(eventId) {
this.deselectEvent();
this.get(eventId).set({selected : true});
},
deselectEvent : function() {
this.getSelectedEvent().set({selected : false});
}
});
最佳答案
尝试覆盖Model.toJSON()
方法,正如您在Backbone Model code中看到的那样,该方法不是很复杂。官方文档还建议在有特殊需要时覆盖它。
尝试这样的事情:
var CSEvent = Backbone.Model.extend({
toJSON: function(){
return _.clone( _.pick( this.attributes, "title", "type", "repeatOrOneTime" ) );
}
});