我有'tabpanel' - 它是'主'形式(視圖)。 在這個'tabpanel'中,我定義了不同的標籤 - xtype'panel'。 所以,我有一個'主'(控制器),'主'視圖和一些標籤視圖。 選項卡的視圖在「主」視圖中引用。在控制器中定義監聽器ExtJS
我想在'main'控制器中定義某個孩子面板的'activate'事件的監聽者。 我該怎麼做?
'主' 控制器:
Ext.define('KP.controller.account.apartment.Main', {
extend: 'Ext.app.Controller',
views: ['account.apartment.Main',
'account.apartment.Requisites'
],
models: ['account.apartment.Requisites'
],
stores: ['account.apartment.Requisites'
],
init: function() {
}
});
'主' 視圖:
Ext.define('KP.view.account.apartment.Main', {
extend: 'Ext.window.Window',
alias: 'widget.ApartmentData',
height: 566,
width: 950,
activeItem: 0,
layout: {
type: 'fit'
},
autoShow: false,
initComponent: function() {
var me = this;
Ext.applyIf(me, {
items: [
{
xtype: 'tabpanel',
activeTab: 0,
deferredRender: true,
items: [
{
xtype: 'RequisitesApartment'
}
]
}
]
});
me.callParent(arguments);
}
});
的子面板RequisitesApartment(視圖):
Ext.define('KP.view.account.apartment.Requisites', {
extend: 'Ext.panel.Panel',
alias: 'widget.RequisitesApartment',
id: 'panel_accountrequisites',
height: 350,
width: 1124,
autoScroll: true,
layout: {
type: 'fit'
},
listeners: {
activate: function() {
....load data....
...this listeners I want to push in 'main' controller...
}
},
initComponent: function() {
var me = this;
var grid_store = Ext.create('KP.store.account.apartment.Requisites');
Ext.applyIf(me, {
dockedItems: [
{
xtype: 'gridpanel',
height: 260,
autoScroll: true,
dock: 'bottom',
store: grid_store,
id: 'r_gridFlatParams',
forceFit: true,
columns: [
...some columns....
],
viewConfig: {
}
}
]
});
me.callParent(arguments);
}
});
好了,'apartServList'不能在你的示例代碼中發現所以我t會難以跟蹤其他人爲什麼這是正確的答案。我包括在內。也許你可以編輯你的問題。 – sra
請注意,我的示例將您指向標籤按鈕本身,而不是標籤。就我所知,選項卡的激活事件沒有冒泡到面板上,不是嗎? – sra
我編輯了我的答案,在'panel'xtype中有'activate'事件。 – Oleg