无法多次打开jQuery UI对话框 - 包含测试用例

时间:2017-10-01 08:26:36

标签: javascript jquery jquery-ui jquery-ui-dialog jquery-ui-button

我准备了a simple test case来证明我的问题 -

我使用jQuery UI按钮打开jQuery UI对话框:

screenshot

然而,这仅适用一次。在随后的按钮单击中,我收到错误:

  

未捕获错误:在初始化之前无法调用对话框上的方法;   试图调用方法'打开'

error in console

即使我在代码中的按钮之前初始化对话框 -

HTML码:

<BUTTON ID="newBtn">New game</BUTTON>

<DIV ID="newDlg" TITLE="New game">
    Select game board:
    <BUTTON value="1">Winter</BUTTON>
    <BUTTON value="2" DISABLED>Spring</BUTTON>
    <BUTTON value="3" DISABLED>Summer</BUTTON>
    <BUTTON value="4" DISABLED>Autumn</BUTTON>
</DIV>

JavaScript的:

var newDlg = $('#newDlg').dialog({
        modal: true,
        autoOpen: false,
        close: function(e, ui) {
                var bid = parseInt($(this).data('bid'));
                $(this).removeData();
                if (1 <= bid && bid <= 4) {
                        alert('selected board id: ' + bid);
                }
        },
        buttons: {
                'Close': function() {
                        $(this).dialog('close');
                }
        }
});

$('#newDlg button').button().click(function(e) {
        e.preventDefault();
        var bid = this.value;
        newDlg.data('bid', bid);
        newDlg.dialog('close');
});

var newBtn = $('#newBtn').button().click(function(e) {
        e.preventDefault();
        newDlg.dialog('open'); // also tried $('#newDlg') here!
});

我尝试过使用jQuery UI 1.11.4和1.12.1,但问题仍然存在。

1 个答案:

答案 0 :(得分:1)

有趣的故事,问题是:

  $(this).removeData();

这将删除所有data属性,包括用于定义对话框的属性。这可以通过定义要删除的特定数据来修复:

  $(this).removeData('bid');

然后按预期工作。

分叉工作示例:https://jsfiddle.net/Twisty/dz8krbye/