298

我有一个 jQuery UI 对话框在我的 ASP.NET 页面上运行良好:

jQuery(function() {
    jQuery("#dialog").dialog({
        draggable: true,
        resizable: true,
        show: 'Transfer',
        hide: 'Transfer',
        width: 320,
        autoOpen: false,
        minHeight: 10,
        minwidth: 10
    });
});

jQuery(document).ready(function() {
    jQuery("#button_id").click(function(e) {
        jQuery('#dialog').dialog('option', 'position', [e.pageX + 10, e.pageY + 10]);
        jQuery('#dialog').dialog('open');
    });
});

我的分区:

<div id="dialog" style="text-align: left;display: none;">
    <asp:Button ID="btnButton" runat="server" Text="Button" onclick="btnButton_Click" />
</div>

但是 btnButton_Click 永远不会被调用......我该如何解决这个问题?

更多信息:我添加了此代码以将 div 移动到表单:

jQuery("#dialog").parent().appendTo(jQuery("form:first"));

但是还是没有成功...

4

17 回答 17

315

您接近解决方案,只是得到了错误的对象。它应该是这样的:

jQuery(function() {
    var dlg = jQuery("#dialog").dialog({
                         draggable: true,
                         resizable: true,
                         show: 'Transfer',
                         hide: 'Transfer',
                         width: 320,
                         autoOpen: false,
                         minHeight: 10,
                         minwidth: 10
                     });
    dlg.parent().appendTo(jQuery("form:first"));
});
于 2009-04-20T13:05:11.750 回答
37
$('#divname').parent().appendTo($("form:first"));

使用此代码解决了我的问题,它适用于所有浏览器、Internet Explorer 7、Firefox 3 和 Google Chrome。我开始喜欢 jQuery... 这是一个很酷的框架。

我也用部分渲染进行了测试,这正是我想要的。伟大的!

<script type="text/javascript">
    function openModalDiv(divname) {
        $('#' + divname).dialog({ autoOpen: false, bgiframe: true, modal: true });
        $('#' + divname).dialog('open');
        $('#' + divname).parent().appendTo($("form:first"));
    }

    function closeModalDiv(divname) {
        $('#' + divname).dialog('close');
    }
</script>
...
...
<input id="Button1" type="button" value="Open 1" onclick="javascript:openModalDiv('Div1');" />
...
...
<div id="Div1" title="Basic dialog" >
    <asp:UpdatePanel ID="UpdatePanel1" runat="server">
       <ContentTemplate>
          postback test<br />
          <asp:Button ID="but_OK" runat="server" Text="Send request" /><br />
          <asp:TextBox ID="tb_send" runat="server"></asp:TextBox><br />
          <asp:Label ID="lbl_result" runat="server" Text="prova" BackColor="#ff0000></asp:Label>
        </ContentTemplate>
    <asp:UpdatePanel>
    <input id="Button2" type="button" value="cancel" onclick="javascript:closeModalDiv('Div1');" />
</div>
于 2009-05-13T09:06:45.510 回答
34

FWIW,形式:第一种技术对我不起作用。

但是,该博客文章中的技术确实:

http://blog.roonga.com.au/2009/07/using-jquery-ui-dialog-with-aspnet-and.html

具体来说,将其添加到对话框声明中:

  open: function(type,data) {
    $(this).parent().appendTo("form");
  }
于 2009-11-11T23:16:58.013 回答
28

请注意,jQuery UI v1.10 中有一个附加设置。添加了一个appendTo设置,以解决您用于将元素重新添加到表单的ASP.NET解决方法。

尝试:

$("#dialog").dialog({
     autoOpen: false,
     height: 280,
     width: 440,
     modal: true,
     **appendTo**:"form"
});
于 2013-05-11T11:01:23.433 回答
25

ken上面的回答对我有用。已接受答案的问题在于,它仅在页面上有单个模式时才有效。如果您有多个模式,则需要在初始化对话框时在“打开”参数中内联,而不是事后。

open: function(type,data) { $(this).parent().appendTo("form"); }

如果您使用多个模式按照第一个接受的答案告诉您的操作,您只会得到页面上的最后一个模式,可以正常触发回发,而不是全部。

于 2010-01-28T21:25:00.903 回答
21

主要是因为 jQuery 使用DOM将对话框移动到表单标签之外。将其移回表单标签内,它应该可以正常工作。您可以通过检查 Firefox 中的元素来看到这一点。

于 2009-04-16T17:49:29.587 回答
8

我不想为我的项目中的每个对话框都解决这个问题,所以我创建了一个简单的 jQuery 插件。此插件仅用于打开新对话框并将它们放置在ASP.NET表单中:

(function($) {
    /**
     * This is a simple jQuery plugin that works with the jQuery UI
     * dialog. This plugin makes the jQuery UI dialog append to the
     * first form on the page (i.e. the asp.net form) so that
     * forms in the dialog will post back to the server.
     *
     * This plugin is merely used to open dialogs. Use the normal
     * $.fn.dialog() function to close dialogs programatically.
     */
    $.fn.aspdialog = function() {
        if (typeof $.fn.dialog !== "function")
            return;

        var dlg = {};

        if ( (arguments.length == 0)
                || (arguments[0] instanceof String) ) {
            // If we just want to open it without any options
            // we do it this way.
            dlg = this.dialog({ "autoOpen": false });
            dlg.parent().appendTo('form:first');
            dlg.dialog('open');
        }
        else {
            var options = arguments[0];
            options.autoOpen = false;
            options.bgiframe = true;

            dlg = this.dialog(options);
            dlg.parent().appendTo('form:first');
            dlg.dialog('open');
        }
    };
})(jQuery);</code></pre>

因此,要使用该插件,您首先加载 jQuery UI,然后再加载该插件。然后您可以执行以下操作:

$('#myDialog1').aspdialog(); // Simple
$('#myDialog2').aspdialog('open'); // The same thing
$('#myDialog3').aspdialog({title: "My Dialog", width: 320, height: 240}); // With options!

需要明确的是,此插件假定您已准备好在调用它时显示对话框。

于 2010-11-10T16:18:42.440 回答
8

我知道这是一个老问题,但是对于任何有同样问题的人来说,有一个更新和更简单的解决方案:jQuery UI 1.10.0 中引入了一个“appendTo”选项

http://api.jqueryui.com/dialog/#option-appendTo

$("#dialog").dialog({
    appendTo: "form"
    ....
});
于 2013-12-14T22:56:42.873 回答
7

极好的!这解决了我的 ASP:Button 事件没有在 jQuery 模态中触发的问题。请注意,使用带有以下内容的 jQuery UI 模式可以触发按钮事件:

// Dialog Link
$('#dialog_link').click(function () {
    $('#dialog').dialog('open');
    $('#dialog').parent().appendTo($("form:first"))
    return false;
});

以下行是使其正常工作的关键!

$('#dialog').parent().appendTo($("form:first"))
于 2010-05-18T13:12:57.427 回答
3

创建对话框后,我刚刚添加了以下行:

$(".ui-dialog").prependTo("form");
于 2012-01-10T07:01:20.227 回答
3

这对我来说是最清晰的解决方案

var dlg2 = $('#dialog2').dialog({
        position: "center",
        autoOpen: false,
        width: 600,
        buttons: {
            "Ok": function() {
                $(this).dialog("close");
            },
            "Cancel": function() {
                $(this).dialog("close");
            }
        }
    });

dlg2.parent().appendTo('form:first');
$('#dialog_link2').click(function(){
    dlg2.dialog('open');

里面的所有内容dlg2都可以插入到您的数据库中。不要忘记更改dialog变量以匹配您的变量。

于 2013-01-15T18:07:02.910 回答
3

使用 ASP.NET 只需UseSubmitBehavior="false"在 ASP.NET 按钮中使用:

<asp:Button ID="btnButton" runat="server"  Text="Button" onclick="btnButton_Click" UseSubmitBehavior="false" />       

参考:Button.UseSubmitBehavior 属性

于 2013-05-08T20:29:24.923 回答
1

以正确的方式移动对话框,但您应该只在打开对话框的按钮中执行此操作。这是 jQuery UI 示例中的一些附加代码:

$('#create-user').click(function() {
    $("#dialog").parent().appendTo($("form:first"))
    $('#dialog').dialog('open');
})

asp:button在对话框中添加您的内容,它运行良好。

注意:您应该在单击“创建用户”按钮后将 <button> 更改为 <input type=button> 以防止回发。

于 2009-04-23T10:55:40.147 回答
1

Robert MacLean 获得最高票数的解决方案是 99% 正确的。但是像我一样,有人可能需要的唯一补充是,每当您需要打开这个 jQuery 对话框时,不要忘记将其附加到父级。如下所示:

var dlg = $('#questionPopup').dialog( 'open'); dlg.parent().appendTo($("form:first"));

于 2009-07-21T14:05:52.203 回答
1

在使用 modal:true 选项时,使用此行来完成这项工作。

open: function (type, data) { 
    $('.ui-widget-overlay').appendTo("form"); $(this).parent().appendTo("form"); 
  },
于 2013-04-05T18:00:40.857 回答
1

$('#dialog').parent().appendTo($("form:first"))解决方案在 IE 9 中运行良好。但在 IE 8 中,它使对话框直接出现和消失。除非您发出一些警报,否则您看不到这一点,因此该对话框似乎永远不会出现。我花了一个上午的时间寻找一个适用于两个版本的解决方案,唯一适用于版本 8 和 9 的解决方案是:

$(".ui-dialog").prependTo("form");

希望这可以帮助其他遇到同样问题的人

于 2013-04-17T10:20:29.970 回答
0

确切的解决方案是;

$("#dialogDiv").dialog({ other options...,
    open: function (type, data) {
        $(this).parent().appendTo("form");
    }
});
于 2013-04-17T10:28:04.940 回答