微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

javascript-未触发metachange事件

我有一家商店,看起来像这样:

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] 举报,一经查实,本站将立刻删除。

相关推荐