我有一个相当通用的模型,并且正在收集该模型(请参见下文),作为一系列观点的基础。在多个视图上,选择其中一个模型会生成操作(通过“ 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" ) );
  }
});

07-24 17:53
查看更多