Cannot add listeners to store in ExtJS Controller

[亡魂溺海] 提交于 2019-12-14 02:52:28

问题


In my application I have a button in a toolbar. If I click on this button to open a window following code is executed:

[...]
onClick: function() {
    this.windowControl = this.getController('attributesearch.Window');
    this.windowControl.init();
    this.windowControl.showWindow();
}
[...]

This window contains some inputfields and a combobox with a store:

Ext.define('EM.store.AttributeQuery', {
    requires: ['EM.model.AttributeQuery'],
    model: 'EM.model.AttributeQuery',
    proxy: {
        type: 'ajax',
        url: './app/configuration/AttributeQueries.json',
        reader: {
            type: 'json',
            root: 'queries'
        }
    },
    autoLoad: true
});

Within the init method of my window controller I want to add one onLoad-listener
I try to add this listener to the store:

init: function() {
        this.getAttributeQueryStore().on('load', this.onStoreLoad, this);
        this.control({
            'attributeSearchWindow': {
                afterrender: this.onWindowRendered
            }
        });
    },

The first line in the init method this.getAttributeQueryStore().on('load', this.onStoreLoad, this); produces the following error:

Uncaught TypeError: Object [object Object] has no method 'on' app/controller/attributesearch/Window.js:9.

It seems the store is not fully (or correct) instantiated. What am I missing?

Edit:

The console output for this.getAttributeQueryStore() is this:

constructor {self: function, superclass: Object, config: emptyFn, initConfigList: Array[0], initConfigMap: Object…}
__proto__: TemplateClass
$className: "EM.store.AttributeQuery"
autoLoad: true
config: emptyFn
configMap: TemplateClass
initConfigList: Array[0]
initConfigMap: Object
model: "EM.model.AttributeQuery"
proxy: Object
requires: Array[1]
self: function constructor() {
superclass: Object
__proto__: Object
}

回答1:


Why don't you just define the store's listener as part of the store's definition?

Ext.define('EM.store.AttributeQuery', {
    requires: ['EM.model.AttributeQuery'],
    model: 'EM.model.AttributeQuery',
    proxy: {
        type: 'ajax',
        url: './app/configuration/AttributeQueries.json',
        reader: {
            type: 'json',
            root: 'queries'
        }
    },
    autoLoad: true,
    listeners: {
       load: function(store, records, options) {
          EM.getApplication().getController('attributesearch.Window').onStoreLoad(store, records, options);
       }
    }
});



回答2:


It is my own fault.

If you have a closer look at my store definition, you will see that i forgot to insert the extent: 'Ext.store.Store'. Thats it. Now i can add and remove listeners like i expected to.

Thank you everyone.



来源:https://stackoverflow.com/questions/18269060/cannot-add-listeners-to-store-in-extjs-controller

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!