Chrome不支持showModalDialog模态对话框和无法返回returnValue问题的解决方法


Posted in Javascript onOctober 30, 2016

What?模态对话框失效了?

上个礼拜修改测试一个后台管理项目,在测试与各个浏览器兼容性的时候,发现在chrome浏览器下showModalDialog方法显示的并不是模态对话框,就像新打开一个页面一样,父窗口仍然可以随意获取焦点,并可以打开多个窗体,而且返回值returnValue也无法返回,一直是undefined。这么多问题很令人头疼,下面就各个主流最新版的浏览器进行了一下测试。

浏览器 是否支持 状态
IE9
Firefox13.0
safari5.1
chrome19.0 × 并不是模态对话框,而是open了一个新窗体
Opera12.0 × 什么也发生,连个窗体都不弹

Chrome到底打开的是什么

因为打开的不是模态对话框,而是像open了一个新窗体一样,那只要验证一下子窗体window.opener是否为空就明白了。

<script type="text/javascript">
    alert(window.opener);
</script>

在chrome中,显示的是一个[object window]对象,而IE则是undefined。现在知道原来chrome将showModalDialog当作window.open来处理了。也就是说我们完全可以用window.opener来操作chrome浏览器下子窗体。这里还发现个很有趣的现象,firefox中测试window.opener也并不为空,于是我又测试了下使用showModalDialog在子窗体中关于window.opener和window.dialogArguments在各个浏览器里的状况,由于Opera浏览器连个窗体都不弹,下面测试就剔除它了。

说明下父窗体的showModalDialog的方法中arguments传递是window对象,下面是测试的结果:

浏览器 模态对话框 window.opener window.dialogArguments returnValue
IE9 undefined [object Window]
Firefox13.0 [object Window] [object Window]
safari5.1 [object Window] [object Window]
chrome19.0 × [object Window] undefined ×

以上是我测试的结果,各个浏览器所支持的程度还是不一样的。还要说一下Firefox浏览器下,子窗体假如刷新的话window.dialogArguments照样会丢失,变成undefined。以上结果中我们可以看出返回值returnValue就只有chrome浏览器返回的是undefined,其他浏览器都没有问题。那该如何解决这个问题呢?

解决returnValue问题

通过以上的种种测试,我们已经知道chrome的showModalDialog方法很像执行了window.open方法,那么我们可以利用window.opener来实现window.returnValue的功能。

注意:temp=Math.random()这个随机参数是为了解决缓存问题,不少朋友测试出undefined是因为是缓存的问题。 追加于2012-10-17

父窗体部分js代码:

window.onload = function () {
  var returnValue = window.showModalDialog("son.html?temp=" + Math.random(), window);
  //for chrome
  if (returnValue == undefined) {
    returnValue = window.returnValue;
  }

  alert(returnValue);
}

子窗体部分js代码:

if (window.opener != undefined) {
    //for chrome
    window.opener.returnValue = "opener returnValue";
}
else {
    window.returnValue = "window returnValue";
}
window.close();

这样也在IE,FireFox,Chrome,Safari等浏览器下都可以通用了。

最后

最后有人要问那该如何实现模态对话框呢?我觉得应该是可以用一些js技巧去实现的,但是我不并推荐这样做,我也查询了很资料都不能很好的解决这个问题。当然,也可以有其他一些思路,比如为了不弹出更多的窗体,可以在点击打开窗体的时候将那个open按钮设置为不可用,只有关闭了子窗体再设置成可用。这些大家都可以自己去实践下,或许有更好的方法。

最后我想说的是在当今的网页设计中很流行用div在页面内去模拟一个窗体,样式自定义,交互都很不错,不一定非要用模态窗体,如何模拟网上一大把,今天就写到这里吧,有什么错误的地方请大家多指正~~

Javascript 相关文章推荐
javascritp实现input输入框相关限制用法
Jun 29 Javascript
js 第二代身份证号码的验证机制代码
May 12 Javascript
Select标签下拉列表二级联动级联实例代码
Feb 07 Javascript
JavaScript设计模式之观察者模式(发布者-订阅者模式)
Sep 24 Javascript
jQuery随机密码生成的方法
Mar 09 Javascript
javascript DOM的详解及实例代码
Mar 06 Javascript
Jquery中attr与prop的区别详解
May 27 jQuery
Vue2.0设置全局样式(less/sass和css)
Nov 18 Javascript
JS计算距当前时间的时间差实例
Dec 29 Javascript
jQuery实现网页拼图游戏
Apr 22 jQuery
vue-router实现编程式导航的代码实例
Jan 19 Javascript
vue ajax 拦截原理与实现方法示例
Nov 29 Javascript
原生JS版和jquery版实现checkbox的全选/全不选/点选/行内点选(Mr.Think)
Oct 29 #Javascript
JavaScript计算值然后把值嵌入到html中的实现方法
Oct 29 #Javascript
JS给Array添加是否包含字符串的简单方法
Oct 29 #Javascript
浅谈js对象属性 通过点(.) 和方括号([]) 的不同之处
Oct 29 #Javascript
jQuery 移动端拖拽(模块化开发,触摸事件,webpack)
Oct 28 #Javascript
RequireJS简易绘图程序开发
Oct 28 #Javascript
jquery配合.NET实现点击指定绑定数据并且能够一键下载
Oct 28 #Javascript
You might like
PHP4之COOKIE支持详解
2006/10/09 PHP
PHP 伪静态隐藏传递参数名的四种方法
2010/02/22 PHP
PHP易混淆函数的区别及用法汇总
2014/11/22 PHP
php安装ssh2扩展的方法【Linux平台】
2016/07/20 PHP
示例详解Laravel重置密码代码重构
2016/08/10 PHP
浅谈thinkphp5 instance 的简单实现
2017/07/30 PHP
JavaScript Array扩展实现代码
2009/10/14 Javascript
jQuery学习笔记之jQuery选择器的使用
2010/12/22 Javascript
Jquery中使用setInterval和setTimeout的方法
2013/04/08 Javascript
JS子父窗口互相操作取值赋值的方法介绍
2013/05/11 Javascript
javascript中拼接HTML字符串的最快、最好的方法
2014/06/07 Javascript
原生JavaScript实现瀑布流布局
2020/06/28 Javascript
基于JavaScript实现前端文件的断点续传
2016/10/17 Javascript
angularJs中跳转到指定的锚点实例($anchorScroll)
2018/08/31 Javascript
vue集成百度UEditor富文本编辑器使用教程
2018/09/21 Javascript
vue19 组建 Vue.extend component、组件模版、动态组件 的实例代码
2019/04/04 Javascript
Vue项目使用localStorage+Vuex保存用户登录信息
2019/05/27 Javascript
vue 强制组件重新渲染(重置)的两种方案
2019/10/29 Javascript
Node.js API详解之 vm模块用法实例分析
2020/05/27 Javascript
Vue性能优化的方法
2020/07/30 Javascript
Python中使用Queue和Condition进行线程同步的方法
2016/01/19 Python
Python generator生成器和yield表达式详解
2019/08/08 Python
python安装virtualenv虚拟环境步骤图文详解
2019/09/18 Python
pyinstaller将含有多个py文件的python程序做成exe
2020/04/29 Python
python logging.info在终端没输出的解决
2020/05/12 Python
Python检测端口IP字符串是否合法
2020/06/05 Python
浅谈OpenCV中的新函数connectedComponentsWithStats用法
2020/07/05 Python
巴西Mr. Cat在线商店:购买包包和鞋子
2019/09/08 全球购物
高中军训感言800字
2014/03/05 职场文书
艺术设计专业个人求职信
2014/04/10 职场文书
党支部换届选举方案
2014/05/08 职场文书
化验室岗位职责
2015/02/14 职场文书
2015年维修工作总结
2015/04/25 职场文书
毕业设计答辩开场白
2015/05/29 职场文书
小程序后台PHP版本部署运行 LNMP+WNMP
2021/04/01 Servers
Nginx location 和 proxy_pass路径配置问题小结
2021/09/04 Servers