<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" />&nbsp;
<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;
});