5

我的场景:

  1. 单击 Dialog1 中的特定元素时,将打开 Dialog2。

  2. 当您按 Escape 关闭 Dialog2 时,按预期工作并关闭 Dialog2。

  3. Dialog1 仍然存在,您会认为可以通过再次点击 Escape 来关闭它,但事实并非如此。您必须先单击对话框,然后单击 Escape 以将其关闭。

这是我尝试过的,但无济于事:

// Array to hold all of our open dialogs id's
var openDialogs = [];

// the open: method in my dialog
open: function() {

    openDialogs[openDialogs.length] = $(this).attr("id");

}

// the close: method in my dialog
close: function() {

    var index = $.inArray($(this).attr("id"), openDialogs),
    $previousDialog = (index > 0) ? $("#" + openDialogs[index]) : undefined;

    // remove the current dialog from the array via Jon Resig's remove() method
    openDialogs.remove(index);          

    // set focus to previously opened dialog
    if ($previousDialog) { $previousDialog.focus(); }

    // I've even tried:
    //
    // if ($previousDialog) { $previousDialog.dialog("moveToTop"); }

}
4

2 回答 2

4

这一行:

var index = $.inArray($(this).attr("id"), openDialogs),
$previousDialog = (index > 0) ? $("#" + openDialogs[index]) : undefined;

$previousDialog参考当前对话框(正在关闭的对话框)。index是正在关闭的对话框的索引。

因此,稍后在此行:

if ($previousDialog) { $previousDialog.focus(); }

正在调用focus()已关闭的对话框。

我相信你想要的是这样的:

close: function() {
    var index = $.inArray($(this).attr("id"), openDialogs),
        $previousDialog = (index - 1 >= 0) ? $("#" + openDialogs[index - 1]) : undefined;

    // remove the current dialog from the array via Jon Resig's remove() method
    openDialogs.remove(index);

    // set focus to previously opened dialog
    if ($previousDialog) {
        $previousDialog.focus();
    }
}

这是一个工作示例:http: //jsfiddle.net/L8J7Y/

我还注意到,如果您$previousDialog.dialog("widget").focus();改用它,您可以避免在对话框周围出现可能令人讨厌的虚线。

于 2011-05-12T01:44:16.497 回答
0

你把这个放在关闭函数中怎么样

 $(".ui-dialog-content").dialog("close");

因为所有对话框都有该类,所以它将关闭所有对话框

于 2011-05-12T01:52:15.740 回答