阻止jQueryUI模式对话框

Réj*_*ôme 30 dialog jquery-ui blockui

我不能让BlockUI在模态对话框上工作.
我试图照顾z-index问题,但没有成功......

在我的网页中,这是头部:

<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.7.1/jquery.min.js" ></script>
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jqueryui/1.8.17/jquery-ui.min.js" ></script>
<script type="text/javascript" src="http://jquery.malsup.com/block/jquery.blockUI.js?v2.38" ></script>
<link media="all" type="text/css" href="http://ajax.googleapis.com/ajax/libs/jqueryui/1.8.17/themes/base/jquery-ui.css" rel="stylesheet" />
Run Code Online (Sandbox Code Playgroud)

和身体:

<div id="dialog_test" title="Test">
    TEST
</div>

<a href="#" id="go">GO</a>

<script>
    $(function() {
        $( "#dialog_test" ).dialog({
            autoOpen: false,
            modal: true,
            buttons: {
                "Cancel": function() {
                    $( this ).dialog( "close" );
                },
                "Ajax": function() {
                    $.ajax({
                        "url" : "http://jquery.malsup.com/block/wait.php",
                        "success" : function(json) {
                            $( "#dialog_test" ).dialog( "close" );
                        }
                    });
                }
            }
        });

        $( "#go" ).click(function(event) {
            event.preventDefault();
            $( "#dialog_test" ).dialog( "open" );
        });

    });

    $(document)
        .ajaxStart(function() {
            $.blockUI({
                theme: true
            })
        })
        .ajaxStop($.unblockUI);

</script>
Run Code Online (Sandbox Code Playgroud)

任何的想法?

Did*_*hys 48

您没有使用z-index指定您尝试过的内容.

blockUI插件有一个选项可以更改它创建的消息的z-index(文档):

// z-index for the blocking overlay 
baseZ: 1000,
Run Code Online (Sandbox Code Playgroud)

jQuery UI Dialog也是指定z-index选项.它的默认值是1000.所以你必须为BlockUI选项设置一个更高的数字,比方说2000:

$.blockUI({
    theme: true,
    baseZ: 2000
})
Run Code Online (Sandbox Code Playgroud)

DEMO

  • 是的,这可以胜任!谢谢. (3认同)