0

我正在使用 extjs 4.1 商店。看起来像这样:

Ext.define('myStore', {
    extend: 'Ext.data.Store',
    requires: ['myModel'],
    autoLoad: false,
    proxy: {
        type: 'ajax',
        url: '/aaa/bbb',
        timeout: '90000',
        reader: {
            type: 'json',
            root: 'data'
        }
    },
    listeners: {
        'beforeload': function (store, options) {
            },
        'load': function (store, options) {

        }
    },
    sorters: [{
        property: 'SortOrder',
        direction: 'ASC'
    }]
});

最初我通过代理加载数据。稍后基于用户交互,我会从 store ussign 中提取数据store.proxy.reader.rawData并将其存储在某个变量中。

然后在稍后阶段,我将使用 loadRawData().

调用 loadRawData()时,它也会触发 load 事件。

我想要什么:我想区分由于代理第一次加载数据而触发的加载事件与由于 loadRawData() 而触发的加载事件。

4

1 回答 1

0

升级到 ExtJS 版本 5.1 允许您访问 store.loadCount ,这将让您检查这是第一次加载还是后续加载。http://docs.sencha.com/extjs/5.1/5.1.0-apidocs/#!/api/Ext.data.Store-property-loadCount

如果您不想升级,您可以手动实现此功能(例如,在您的商店中的“加载”侦听器中增加一个自定义变量)并检查它以查看您想要执行的行为。

于 2015-05-19T10:13:01.090 回答