我正在使用Marionette
,我有以下问题。
我创建了一个包含两个不同区域的布局。在initialize
布局上加载我布局的两个区域中的两个视图。说ViewA
和ViewB
。在ViewA
一个事件内被触发。该事件被布局消耗以切换并注入其他两个视图。说ViewC
和ViewD
。每当执行切换时,ViewC
并且ViewD
没有我应用于它们的相同样式(也是 css)。特别是,没有应用 jQuery Mobile 样式。有什么建议吗?
这里有一些代码,其中注释突出显示了重要部分。
onConfirm : function() {
this.leftView = new ViewC();
this.rightView = new ViewD();
this.leftRegion.show(this.leftView);
this.rightRegion.show(this.rightView);
// FIX calling trigger('create') seems fix the problem. Why? Is this correct?
this.$el.trigger('create');
},
initialize : function() {
// listen for event triggered from ViewA
// e.g. GloabalAggregator.vent.trigger("ga:confirm");
// where "ga:confirm" is a simple string
GloabalAggregator.vent.on("ga:confirm" , this.onConfirm, this);
this.leftView = new ViewA(), // creating here a new ViewC the style is applied correctly
this.rightView = new ViewB(); // creating here a new ViewD the style is applied correctly
},
onRender : function () {
this.leftRegion.show(this.leftView);
this.rightRegion.show(this.rightView);
}
编辑
打电话trigger('create')
似乎可以解决问题。为什么?它是否正确?