天天看点

JQuery EasyUI弹出对话框解决Asp.net服务器控件无法执行后台代码的方法

    <script language="javascript">

        $(function(){

            var dlg = jQuery("#dd").dialog({

                draggable: true,

                resizable: true,

                closed:true,

                show: 'Transfer',

                hide: 'Transfer',

                autoOpen: false,

                width:600,

                minHeight: 10,

                minwidth: 10

            });

        });

        function open1(){

            $('#dd').dialog('open');

        }

        function close1(){

            $('#dd').dialog('close');

    </script>

对应的弹出层内容如下所示:

        <div id="dd" title="处理流程" icon="icon-save" style="overflow:auto;padding:10px;">

        <table width="100%" cellpadding="0" cellspacing="1" border="0" id="Table1">

            <tr>

                <td >

                    <asp:DataGrid ID="dg" runat="server" Width="100%" CssClass="dg" AutoGenerateColumns="False"

                PageSize="20" AllowSorting="True" DataKeyField="ID" Height="0px" OnItemDataBound="dg_ItemDataBound">

                <EditItemStyle CssClass="EditItem"></EditItemStyle>

                <AlternatingItemStyle CssClass="AlternatingItem"></AlternatingItemStyle>

                <ItemStyle CssClass="Item"></ItemStyle>

                <HeaderStyle CssClass="Header"></HeaderStyle>

                <FooterStyle CssClass="Footer"></FooterStyle>

                <Columns>

                    <asp:TemplateColumn HeaderText="ID" Visible="false">

                        <ItemTemplate>

                            <asp:Label ID="lblId" runat="server" Text='<%# DataBinder.Eval(Container, "DataItem.id") %>'></asp:Label>

                        </ItemTemplate>

                    </asp:TemplateColumn>

                    <asp:TemplateColumn HeaderText="序号">

                            <asp:Label ID="lblOrderbyId" runat="server" Text='<%# DataBinder.Eval(Container, "DataItem.OrderbyId") %>'></asp:Label>

                    <asp:TemplateColumn HeaderText="处理类型">

                            <asp:Label ID="lblproctype" runat="server" Text='<%# DataBinder.Eval(Container, "DataItem.proctype") %>'></asp:Label>

                    <asp:TemplateColumn HeaderText="流程名称">

                            <asp:Label ID="lblflowname" runat="server" Text='<%# DataBinder.Eval(Container, "DataItem.flowname") %>'></asp:Label>

                    <asp:TemplateColumn HeaderText="流程处理人">

                            <asp:Label ID="lblproc_user" runat="server" Text='<%# DataBinder.Eval(Container, "DataItem.procuser") %>'></asp:Label>

                            <asp:DropDownList ID="ddlproc_user" runat="server" Visible="false" />

                    <asp:TemplateColumn HeaderText="流程步骤描述">

                            <asp:Label ID="lblmayaddflow" runat="server" Text='<%# DataBinder.Eval(Container, "DataItem.flownote") %>'></asp:Label>

                </Columns>

            </asp:DataGrid>

                </td>

            </tr>

        </table>

        <table class="formitem_pagestyle" cellspacing="0" cellpadding="0" border="0" style="width: 100%;

            border-collapse: collapse;">

                <td class="pagebutton" align="right" style="height: 30px; width: 100%;">

                    <asp:ImageButton ID="imgbtnOK" runat="server" ImageUrl="~/Themes/Default/btn_savetobox.gif"

                        OnClick="imgbtnOK_Click" /> 

                    <img src="http://www.cnblogs.com/Themes/Default/btn_close.gif" border="0" onclick="close1()"/>

        </div>  

        <br /><br />

        <div align="center">   

            <img src="http://www.cnblogs.com/Themes/Default/btn_savetobox.gif" border="0" onclick="open1()"/>

            <asp:ImageButton ID="imgbtnBack" runat="server" ImageUrl="~/Themes/Default/btn_back.gif"

                        CausesValidation="false" OnClick="imgbtnBack_Click" />

         </div>   

搜索相关问题发现,其中主要问题是出在:JQuery会把Dialog的元素append到Body里面,而不是form里面。研究了页面源码后发现,jQuery UI Dialog控件初始化时动态生成的HTML元素被添加到页面的尾部、form元素的后面,而原始的Dialog模板部分(其内包含表单元素)也被移到了 动态生成的HTML元素内。也就是说,原先在form内的表单在Dialog初始化后就被移到form外了,这就导致了Dialog模板内表单全部失效。

解决方法是增加一行代码即可:dlg.parent().appendTo(jQuery("form:first")); 

也就是修改开始部分创建对话框的脚本即可:

            dlg.parent().appendTo(jQuery("form:first"));

    </script> 

 另外你也可以通过这种方法来处理该问题:

     $('#dialog_link').click(function () { 

       $('#dialog').dialog('open');

        $('#dialog').parent().appendTo($("form:first"))

        return false;

    });

继续阅读