ExtJS loadMask:在多个ajax调用中管理几个loadMask

时间:2012-02-03 16:46:49

标签: ajax extjs request loading mask

在我的应用中,我需要同时执行几个ajax请求,但每个请求根据响应大小需要不同的时间。为了避免在ajax请求期间进一步操作,我想在每个ajax调用中使用Ext.LoadMask,如下所示:

for(var i=0; i<ajaxCount; i++) {
    var loadMask = new Ext.LoadMask(Ext.getBody(), {msg:"Loading " + ajaxName[i]});
    Ext.Ajax.request({
        success: function() {
            loadMask.hide();
        },
        failure: function() {
            loadMask.hide();
        }
    }
}

然而,我发现hide()将隐藏内存中的所有loadMaskes。我想要做的只是隐藏这个ajax请求中的那个,这样在所有请求结束之前总会有一个掩码。

还有另一种实现方法吗?

谢谢!

1 个答案:

答案 0 :(得分:6)

为什么不对所有请求使用相同的掩码,并在返回所有请求后删除它?

var requestCounter = 0;
function hideMask(){
    if (requestCounter > 1){
        requestCounter--;
    } else {
        loadMask.hide();
    }
}
if (ajaxCount > 0){
    var loadMask = new Ext.LoadMask(Ext.getBody(), {msg:"Loading"});
}

for(var i=0; i<ajaxCount; i++) {    
    requestCounter++;
    Ext.Ajax.request({
        success: hideMask,
        failure: hideMask
    }
}