5

我已经实现了块 UI,因为这个请求可能需要一点时间,当 ajax 请求启动时,一切都按预期工作。

但是当 ajax 请求完成并显示 msgbox 时,UI 不会解除阻塞!

有任何想法吗?

我正在使用 IE8。

$().ajaxStart($.blockUI); 
$().ajaxStop($.unblockUI); 

function ChangeCompanyState(companyId, state) {
    var parameters = "{companyId:" + companyId + ",state:\"" + state + "\"}";
    $.ajax({
        type: "POST",
        url: "Ajax/AjaxFragments.aspx/ChangeCompanyState",
        data: parameters,
        contentType: "application/json; charset=utf-8",
        dataType: "json",
        success: function(msg) {
            if (msg.d.length > 1) {
                alert(msg.d);
                $.unblockUI();
            }
            else {
                //Theres no message to process success.
                window.location.reload();
            }
        }

    });
}
4

3 回答 3

8
$.unblockUI();
$(".blockUI").fadeOut("slow"); 
于 2009-11-02T15:16:17.267 回答
4

我也有同样的情况,并通过在 unbluckUI 句子中使用 parentesis 来解决。

// block when ajax activity starts
function beginRequestHandler(sender, args) {
    $.blockUI({ message: '<h1><img src="loading.gif" /> Just a moment...</h1>' });
}

// unblock when ajax activity stops 
function endRequestHandler(sender, args) {
    $.unblockUI(); // previously was $.unblockUI;
}

HTH 米尔顿

于 2010-10-15T13:08:09.950 回答
0

如此所述,使用

<meta http-equiv="X-UA-Compatible" content="IE=7" />

似乎解决了这个问题。在我自己的项目中,我没有得到任何其他方法来解决它。

于 2009-10-06T16:17:06.163 回答