我有一个JQuery UI模式对话框的问题。我有模态对话框(dialogA),它可以创建另一个模态对话框(dialogB)。在dialogB的第二次创建和关闭之后,dialogA的覆盖消失。Jquery UI模式对话框
这里是我的代码:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" >
<head><link type="text/css" rel="Stylesheet" href="ui-lightness/jquery-ui-1.8.custom.css" />
<script type="text/javascript" src="jquery-1.4.2.min.js"></script>
<script type="text/javascript" src="jquery-ui-1.8.custom.min.js"></script>
<script type="text/javascript">
function createDialog(dialogId) {
$('#' + dialogId).dialog({
autoOpen: true,
modal: true,
buttons: {
'close': function() {
$(this).dialog('close');
},
'create': function() {
var newDialogId = dialogId + '1';
$('body').append('<div id="' + newDialogId + '">' + newDialogId + '</div>');
createDialog(newDialogId);
}
},
close: function() {
$(this).dialog('destroy');
$(this).remove();
}
});
}
$(document).ready(function() {
$('#button1').click(function() {
var dialogId = 'dialog';
$('body').append('<div id="' + dialogId + '">' + dialogId + '</div>');
createDialog(dialogId);
});
});
</script>
</head>
<body>
<button id="button1">Create dialog</button>
</body>
</html>
重现步骤:
1.单击按钮
2.创建另一个对话框创建一个对话框(对话)(dialogA)通过点击第一个对话框中的“创建”按钮
3.关闭对话框A
4.重复步骤2-3
第一个对话框的5.覆盖已经消失
感谢
差别看起来像一个bug,如果为同一个z-index创建两次模态对话框,叠加层将会破坏。你能手动增加z-index吗? 作为替代,你可以通过一些插件,例如http://flowplayer.org/tools/demos/overlay/modal-dialog.html – 2010-04-15 16:47:05