我在试图弄清楚如何从一个视图控制器中监听另一个视图控制器中触发的事件时遇到了问题。
我的网格组件定义了一个监听器。
selModel: {
listeners: {
selectionchange: 'onChemClick'
}
},
我的ViewController(称为chemslist)具有触发另一个事件的功能。
onChemClick: function(view, selected) {
console.log("before firing");
this.fireEvent('canvasData', this, selected.length);
console.log("after firing");
console.log(selected);
}
我有另一个控制器实际上监听此事件并显示数据。
Ext.define('view.canvas.CanvasController', {
extend: 'Ext.app.ViewController',
alias: 'controller.canvas',
listen: {
controller: {
chemslist: {
canvasData: 'onCanvasData'
}
}
},
onCanvasData: function() {
console.log("At Fire");
}
});
由于某种原因,我无法确定为什么CanvasController不能监听事件。我还查看了Ticket示例,并了解了如何触发事件以及其他viewControllers如何监听它们。
此外,如果在一个区域的网格选择会导致另一个面板中发生许多更改,那么最佳实践是什么?是否应该将事件作为全局触发,以便所有组件都可以监听它?或者应该在主控制器(而不是视图控制器)中监听它,并根据事件生成组件?
谢谢!