JS模态窗口返回值兼容问题解决方案
2015-01-04 22:16
267 查看
因系统要兼容原IE已使用的关闭方法,经调试测得,需对window.dialogArguments进行再较验,不然易出问题。
function OKEnd(vals) {
if (vals == null) vals = "TRUE";
if (typeof (window.opener) == "undefined") {
if (typeof (window.dialogArguments) != "undefined") {
if (window.dialogArguments && window.dialogArguments != null) {
window.opener = window.dialogArguments;
if (window.opener && window.opener != null) {
window.opener.ReturnValue = vals;
}
}
}
}
else {
if (window.opener && window.opener != null) {
window.opener.ReturnValue = vals;
}
}
window.returnValue = vals;
self.close();
}
返回值接收的,只需在原有IE的接收模式下,多较验一下opener就可以了,如下:
//选择变更部门
function SetOrganizeTree2() { var url="弹出页面";
var ret = window.showModalDialog(url, window, "dialogWidth=400px;dialogHeight=500px;status=no;help=no;scroll=yes;resizable=yes;");
<span style="color:#ff0000"> if (typeof (ret) == "undefined") {
ret = window.ReturnValue;
}</span>
if (ret) {
document.getElementById("hidDeptCode2").value = ret;
document.getElementById("btnDeptCodeAdd").click();
}
return false;
}
-----------------------------------------------------------------------------------------------------------------------
1、打开弹出窗口时把 window 作为第二个参数传入。
var result = window.showModalDialog(url, window, "dialogWidth=" + width + "px;dialogHeight=" + height + "px;resizable:yes;")
if (typeof (result) == 'undefined') {
result = window.ReturnValue;
}
return result;
2、在弹出窗口中,执行如下JS,以接收传入的window
if (typeof (window.opener) == 'undefined') window.opener = window.dialogArguments;
3、弹出窗口关闭前,调用如下JS赋返回值
window.retureValue = vals;
if (window.opener && window.opener != null)
window.opener.ReturnValue = vals;
window.close();
博客园davidyang78原创,转载请保留此信息
原理探讨:
chrome下,标准方法,在弹出页面不回发的情况下,是可以返回值的。 有回发则不能正常返回值。此方法可以解决。
IE下标准方法,有时不明原因不能正确返回值,此方法可解决。
FF未详细测试,应该问题不大。
function OKEnd(vals) {
if (vals == null) vals = "TRUE";
if (typeof (window.opener) == "undefined") {
if (typeof (window.dialogArguments) != "undefined") {
if (window.dialogArguments && window.dialogArguments != null) {
window.opener = window.dialogArguments;
if (window.opener && window.opener != null) {
window.opener.ReturnValue = vals;
}
}
}
}
else {
if (window.opener && window.opener != null) {
window.opener.ReturnValue = vals;
}
}
window.returnValue = vals;
self.close();
}
返回值接收的,只需在原有IE的接收模式下,多较验一下opener就可以了,如下:
//选择变更部门
function SetOrganizeTree2() { var url="弹出页面";
var ret = window.showModalDialog(url, window, "dialogWidth=400px;dialogHeight=500px;status=no;help=no;scroll=yes;resizable=yes;");
<span style="color:#ff0000"> if (typeof (ret) == "undefined") {
ret = window.ReturnValue;
}</span>
if (ret) {
document.getElementById("hidDeptCode2").value = ret;
document.getElementById("btnDeptCodeAdd").click();
}
return false;
}
-----------------------------------------------------------------------------------------------------------------------
1、打开弹出窗口时把 window 作为第二个参数传入。
var result = window.showModalDialog(url, window, "dialogWidth=" + width + "px;dialogHeight=" + height + "px;resizable:yes;")
if (typeof (result) == 'undefined') {
result = window.ReturnValue;
}
return result;
2、在弹出窗口中,执行如下JS,以接收传入的window
if (typeof (window.opener) == 'undefined') window.opener = window.dialogArguments;
3、弹出窗口关闭前,调用如下JS赋返回值
window.retureValue = vals;
if (window.opener && window.opener != null)
window.opener.ReturnValue = vals;
window.close();
博客园davidyang78原创,转载请保留此信息
原理探讨:
chrome下,标准方法,在弹出页面不回发的情况下,是可以返回值的。 有回发则不能正常返回值。此方法可以解决。
IE下标准方法,有时不明原因不能正确返回值,此方法可解决。
FF未详细测试,应该问题不大。
相关文章推荐
- JS模态窗口返回值兼容问题解决方案
- JS模态窗口返回值兼容问题解决方案
- JS模态窗口返回值兼容问题解决方案
- JS模态窗口返回值兼容问题解决方案
- JS模态窗口返回值兼容问题的完美解决方法
- JS模态窗口返回值兼容问题解决办法
- prototype.js的Ajax对IE8兼容问题解决方案
- 移动端模态窗口的滚动和橡皮筋问题解决方案
- js通过window.external调用delphi的返回值类型问题解决方案,不解的COM问题
- IE浏览器各版本与web标准不兼容问题解决方案
- [导入]解决JS页面跳转ie,firefox,opera不兼容问题
- 火狐不执行js的一些解决办法及火狐对js的兼容问题
- 解决js常见的模态窗体显示报错的问题
- JavaScript js 兼容浏览器问题 兼容FireFox(FF)、IE的解决方法
- 求解决js打开关闭框架不能兼容ff的问题
- 火狐不执行js的一些解决办法及火狐对js的兼容问题
- 解决模态窗体中出现服务器端交互就弹出新窗口的方案
- window.showdialog完全手册,解决模态窗口,传值和返回值问题
- 解决extjs在firefox中关闭窗口再打开后iframe中js函数访问不到的问题
- window.showdialog完全手册,解决模态窗口,传值和返回值问题