教程集 www.jiaochengji.com
教程集 >  jQuery  >  jquery 教程  >  正文 jQuery UI的Dialog无法提交问题的解决方法

jQuery UI的Dialog无法提交问题的解决方法

发布时间:2013-07-18   编辑:jiaochengji.com
最近在使用jQuery UI的Dialog控件时发现如果在此控件放置表单,则所有表单均无法正常提交
最近在使用jquery ui的Dialog控件时发现如果在此控件放置表单,则所有表单均无法正常提交 具体表现为:
1.提交按钮失效,点击后无任何反应。
2.即便是使用其它手段使页面产生提交,服务器端也无法取到Dialog中的表单数据。

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

第1种方法:
不知jQuery UI的Dialog这样设计是一项功能还是一个bug。为了在Dialog内实现正常的页面提交,根据上述分析,我找到一个简单的解决办法——在 jQuery UI控件的“open”事件处理程序中将Dialog控件动态生成的HTML元素移到form元素内,代码如下:
使用代码:$("#dialog").parent().appendTo("/html/body/form[0]");
或者
$("#dlg").dialog({
open: function () {
$("body > div[role=dialog]").appendTo("form#aspnetForm");
}
});
代码中的“aspnetForm”是ASP.NET应用程序自动生成的当前页面form元素ID,使用时你可以换成自己页面的form ID。

第2种方法:
加入一个<div id="dialog_target"></div>这样的DIV,然后把Dialog写入这个DIV里面。
$("#dialog").parent().appendTo("#dialog_target");

第3种方法:
1、修改Dialog的JS代码,把代码添加到form中,而不是body里面
2、Dialog内部的自定义HTML不使用,而直接加入一个IFRAME,把里面的HTML移到另外的页面中,再与父页面进行交互就OK(我使用的就是这种方法,这样这些独立出来的代码还可以复用

第2种方法,服务器事件可以响应,效果也不错,可以优先考虑。

您可能感兴趣的文章:
jQuery UI 教程之二 ——jquery ui dialog的使用
jQuery UI的Dialog无法提交问题的解决方法
jQuery UI Dialog控件中的表单无法正常提交的解决方法
jquery ui dialog ie8出现滚动条的解决方法
jQuery UI 教程之一 ——入门
jQuery UI Dialog 创建友好的弹出对话框实现代码
jquery ui dialog里调用datepicker的问题
jQuery ui1.7 dialog只能弹出一次问题
JQuery Dialog的内存泄露问题解决方法
jquery dialog open后,服务器端控件失效的快速解决方法

[关闭]
~ ~