gridPanel判断store是否正在加载数据
通过gridPanel的loadMask对象来判断数据是否在加载,
gridPanel里要设置loadMask为true才行
if(true == grid.loadMask.el.isMasked()){
Ext.Msg.alert("提示","正在加载数据...");
return;
}
grid.loadMask.el.isMasked()//获得grid的loadMask对象,判断是否Maske,相当于是否显示出来,显示出来返回true
没有返回undefinded
经过查看源代码,可以用下面的实现:(loadMash也是查看源代码发现的)
store为页面gridPanel的store 对象
store.proxy.on('load',function(){
alert("store.proxy.load");
});
通过store的proxy添加load事件就行了,load为数据加载完成后执行的事件
通过查看源码发现:Ext.data.Store的load()方法是调用她的execute()方法
而execute()方法里就有那些代码,有些看不了,发现她调用了她的
if (doRequest !== false) {
if (this.writer && this.proxy.url && !this.proxy.restful && !Ext.data.Api.hasUniqueUrl
(this.proxy, action)) {
options.params.xaction = action;
}
this.proxy.request(Ext.data.Api.actions[action], rs, options.params, this.reader,
this.createCallback(action, rs, batch), this, options);
}
调用了她的proxy的request方法,经过查找API发现store的proxy为Ext.data.DataProxy,所以在Ext.data.DataProxy
里就查找到load事件,然后再测试了一下,这个还得感谢EXtJS3.2.0中文API的翻译,2010年底的时候,大概在10月左
右,当时因为上家公司项目紧急,天天加班到晚上9点,家里没联网,所以当时和MM(大漠穷秋)他们一起翻译,我就没有翻译,再在就用的他们翻译的文档,呵呵!现在真有点后悔没翻译,不然我的QQ名称也在这文档上,那个开心肯定不说了,以后找MM一起翻译,呵呵!