2

所以我的 UI 上有一个按钮,可以调用这个 Javascript 函数:

function OpenHistory(transactionId, spanThatWasClicked)
    {   
        $.ajax({
            type: "POST",
            url: "<%= Url.Action("ViewHistory", "Indications") %>",
            data : { transactionId : transactionId },
            success: function(data) {
                $("#history").html(data);
                $("#history").dialog({
                    modal: true,
                    resizable: false,
                    title: "Valuation History",
                    width: 850,
                    height: 500,
                    autoOpen: true,
                    buttons: { "Close": function () { $(this).dialog("close"); } }
                });
            }
        });
    }

它的#history设置在页面上看起来像这样:<div id="history"></div>

我第一次点击它——进行 AJAX 调用,打开对话框,一切看起来都很完美。

关闭对话框

我第二次点击它 - 没有任何反应。它会进行 AJAX 调用和所有操作,但屏幕上不会出现任何对话框。

刷新页面

就像上次一样,它只在第一次点击时再次工作。

这是一些奇怪的对话吗?

谢谢。

4

3 回答 3

2

尝试将成功代码更改为:

      success: function(data) {
            $("#history").html(data)
             .dialog({
                modal: true,
                resizable: false,
                title: "Valuation History",
                width: 850,
                height: 500,
                autoOpen: true,
                buttons: { "Close": function () { $(this).dialog("close"); } }
            }).dialog('open');
        }

这样,它将确保dialog('open')它在调用时打开

于 2011-05-04T18:37:10.340 回答
0

autoOpen我认为这是因为一旦没有在后续调用中触发,就已经创建了对话框。尝试添加$("#history").dialog("open")ajax 调用,看看是否有帮助。您可以添加一些优化以确保您不会两次调用原始对话框创建代码(某种布尔变量)

于 2011-05-04T18:36:01.230 回答
0

您应该只调用一次来创建对话框

           $("#history").dialog({
                modal: true,
                resizable: false,
                title: "Valuation History",
                width: 850,
                height: 500,
                autoOpen: true,
                buttons: { "Close": function () { $(this).dialog("close"); } }
            });

打开对话调用$("#history").dialog("open");

我建议在首次加载页面时创建对话框autoOpen: false并根据需要打开它们

于 2011-05-04T18:37:05.847 回答