19

这是我对收藏的看法

var mssg = mssg || {};

mssg.MessagesView = Backbone.View.extend({

el: '#messages',

initialize: function() {
    this.collection.fetch();
    this.collection.bind('reset', this.render, this);
},

render : function() {
    this.$el.html('');
    this.collection.each(function( item ) {
        this.renderMessage( item );
    }, this );
    return this;
},

renderMessage : function( item ) {
    var messageView = new mssg.MessageView({
        model : item
    });
    this.$el.append( messageView.render().el );
}

});

这是收藏

var mssg = mssg || {};

mssg.Messages = Backbone.Collection.extend({
    model : mssg.Message,
    url : 'messages'
});

这就是它的初始化方式:

var mssg = mssg || {};

$(function() {
    new mssg.MessagesView({
        collection : new mssg.Messages()
    });
});

问题是render绑定到的函数reset在 ajax 获取请求后不会触发。

如果我将它绑定到add它工作。我尝试绑定all到一个调试函数,它说该sync事件是与add每个项目一起调用的。

4

2 回答 2

35

如果您检查主干更改日志,您会看到 1.0 中处理 fetch 的方式发生了变化:

将 Collection 的“更新”重命名为 set,以实现与类似 model.set() 的并行性,并与 reset 形成对比。它现在是获取后的默认更新机制。如果您想继续使用“重置”,请通过 {reset: true}

因此,要触发重置事件,您现在必须使用

this.collection.fetch({reset: true})
于 2013-03-24T20:12:30.497 回答
0

在骨干网 1.0 中,您必须手动触发重置:

youColloection.fetch({reset: true});
于 2013-12-11T12:08:50.693 回答