动态加载的模式,可以提交到不同于主页面的URL

时间:2012-09-06 20:32:12

标签: asp.net webforms updatepanel modal-dialog jquery-ui-dialog

我有一个“testMain.aspx”页面,显示可编辑的列表视图。此外,它还包含一个触发jquery UI模式对话框的按钮,该对话框动态加载“testModal.aspx”。此模式包含用户选择的下拉列表,并单击按钮以提交回服务器。我希望模态提交(到testModal.aspx),然后关闭,所以我正在查看testMain.aspx。

我遇到的问题是提交后&关闭模态,任何点击(即链接按钮编辑列表视图)现在提交到modal.aspx而不是main.aspx。

注意:

  • testMain.aspx使用母版页(包含表单元素)
  • listview包含在asp:updatepanel
  • 在我加载(.load())模式之前不会出现问题,在此之前,我的点击回发到testMain.aspx(如预期的那样)

Masterpage.master

<%@ Master Language="VB" CodeFile="MasterPage.master.vb" Inherits="MasterPage" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html>
<head id="Head1" runat="server">
    <asp:ContentPlaceHolder ID="head" runat="server">
    </asp:ContentPlaceHolder>
</head>
<body>
    <div id="page">
        <form id="form1" runat="server">
        <table summary="" class="pageTable">
            <tr>
                <td class="contentArea">
                    <asp:ContentPlaceHolder ID="ContentPage" runat="server">
                    </asp:ContentPlaceHolder>
                </td>
            </tr>
        </table>
        </form>
    </div>
</body>
</html>

testMain.aspx

<script type="text/javascript">
    $(document).ready(function () {
        var $dialog = $('#foo').dialog({
            autoOpen: false,
            modal: true
        });

        $("#foo").parent().appendTo($("form:first"));

        $('#fooBtn').click(function () {
            $dialog.load('testModal.aspx');
            $dialog.dialog('open');
            return false;
        });
    });
</script>

<ajax:UpdatePanel runat="server" ID="updPanelGrid" UpdateMode="Conditional" RenderMode="Inline"
    ChildrenAsTriggers="false">
    <ContentTemplate>
        <asp:ListView ID="ListView1" runat="server" EnableModelValidation="True"
         ...
        </asp:ListView>
    </ContentTemplate>
    <Triggers>
        <ajax:AsyncPostBackTrigger ControlID="listview1" EventName="ItemEditing" />
        <ajax:AsyncPostBackTrigger ControlID="listview1" EventName="ItemDeleting" />
        <ajax:AsyncPostBackTrigger ControlID="listview1" EventName="ItemCanceling" />
        <ajax:AsyncPostBackTrigger ControlID="listview1" EventName="ItemUpdating" />
        <ajax:AsyncPostBackTrigger ControlID="listview1" EventName="ItemInserting" />
    </Triggers>
</ajax:UpdatePanel>

testModal.aspx

<form id="form1" runat="server">
<asp:ToolkitScriptManager ID="ToolkitScriptManager2" runat="server">
</asp:ToolkitScriptManager>
<div>
    <ajax:UpdatePanel ID="updPnl" runat="server">
        <ContentTemplate>
            <asp:LinkButton ID="btnModalSubmit" runat="server" Text="Modal Server Submit" />
            <div>
                The current time is:
                <%= Now.ToString%></div>
        </ContentTemplate>

    </ajax:UpdatePanel>
</div>
</form>

在我看来,通过在jquery对话框上调用.load(),它会导致对updatepanel(即回发路径)的破坏。如何在模式中加载整个.net页面,单击所述模式中的按钮,将其发回服务器(异步),并允许我在模式解除后继续在我的主页面中工作?

这甚至可能吗?有没有更好的办法?

1 个答案:

答案 0 :(得分:0)

在aspx文件中只能有一个Form runat = server。 让你在iframe中加载模态,这应该可以解决问题。 (假设它已经没有像那样加载它)