gpt4 book ai didi

backbone.js - 当模型从集合中移除时,Marionette CollectionView 会重新渲染

转载 作者:行者123 更新时间:2023-12-01 09:28:46 25 4
gpt4 key购买 nike

我发现了我的问题,但我想知道为什么,以便我可以(希望)更好地理解 Marionette/backbone。

问题下面的代码确实会在删除项目时更新 View :

var MainView = Marionette.ItemView.extend({
template: "#sample-template",
events :{
"click #remove" : "remove"
},
remove: function(){
this.trigger("property:remove", this.model);
}
});
var CollectionView = Marionette.CollectionView.extend({
itemView: MainView,
initialize: function(){
this.on("itemview:property:remove", function(view, model){
alert(this.collection.length);
this.collection.remove(model);
alert(this.collection.length);
});
}
});

A JsFiddle to view in all its glory

修复下面的代码确实按预期更新了 View :

var MainView = Marionette.ItemView.extend({
template: "#sample-template",
triggers :{
"click #remove" : "property:remove"
},
});

var CollectionView = Marionette.CollectionView.extend({
itemView: MainView,
initialize: function(){
this.on("itemview:property:remove", function(view, model){
alert(this.collection.length);
this.collection.remove(view.model);
alert(this.collection.length);
});
}
});

The jsFiddle

最佳答案

Backbone.View 定义了一个名为 remove 的方法,用于从 DOM 中移除 View 。您的第一个示例覆盖了该方法。

如果您将 remove 重命名为 removeIt 之类的名称,则名称冲突将消失,代码按预期工作。无论如何,我认为第二种方法更适合这种情况。

关于backbone.js - 当模型从集合中移除时,Marionette CollectionView 会重新渲染,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18699057/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com