我有一家商店,看起来像这样:
Ext.define('GridGeneral.store.GridGeneralStore',{
extend:'Ext.data.Store',
model:'GridGeneral.model.GridGeneralModel',
autoLoad:true,
proxy:{
type:'ajax',
url:'/api/grid/gridgeneralstore.PHP',
reader:{
type:'json'
}
}
});
在控制器内部,我想触发“ Metachange”事件.我尝试这样做:
init:function(){
Ext.getStore('GridGeneralStore').addListener('Metachange',this.MetaChanged, this);
//^^^not fired
Ext.getStore('GridGeneralStore').addListener('load',this.loaded, this);
//^^^ this is ok
},
MetaChanged:function(store, Meta){
console.log('MetaChanged'); // see nothing in the colsole
},
loaded:function(){
console.log('loaded'); // everything works fine!
}
那么,我在做什么错呢?
解决方法:
仅在rolldrum元数据已更改时才触发Metachange事件.这意味着当您的json数据源包含MetaData对象时,代理的阅读器将看到该内容并触发该事件.
http://docs.sencha.com/extjs/5.1/5.1.1-apidocs/#!/api/Ext.data.reader.Reader-property-metaData
JSON:
{
data: [{ ... }],
msg: "...",
total: 99,
MetaData: {
fields: [{ ... }],
columns: [{ ... }],
idProperty: "id",
messageProperty: "msg",
root: "data"
}
}
例:
http://docs.sencha.com/extjs/4.2.3/extjs-build/examples/data/meta-config-basic.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。