我有一个使用具有多个区域的布局作为 ItemView 的 CompositeView:
var CompositeView = Backbone.Marionette.CompositeView.extend({
itemView: Layout,
template: _.template(...)
});
var Layout = Backbone.Marionette.Layout.extend({
template: _.template(...),
regions: {
mainRegion: ".main",
listRegion: ".list"
},
onRender : function () {
this.mainRegion.show(new SingleView({model : this.model}));
}
});
var SingleView = Backbone.Marionette.ItemView.extend({
template: _.template(...),
initialize: function(){
// Forward view events - is there a better way?
this.on('Module:submodule:action1', function(ev){
app.vent.trigger("Module:submodule:action1", ev);
});
},
triggers: {
"click .ui_toggleComplete": "Module:submodule:action1",
}
});
这使得通过 app.on('Module:submodule:action1',...); 接收 SingleView 事件成为可能。
我想直接使用模型事件而不将它们转发到事件聚合器(app.vent)。
在我将布局实现为 itemView 之前,我可以做类似 CompositeView.on('itemview:Module:submodule:action1',...); 这就是我想再次处理 ItemViews 事件的方式。(我需要布局来显示更多的收藏等......)