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 相关文章推荐
兼容FireFox 的 js 日历 支持时间的获取
Mar 04 Javascript
JavaScript replace(rgExp,fn)正则替换的用法
Mar 04 Javascript
JS+DIV实现鼠标划过切换层效果的实例代码
Nov 26 Javascript
屏蔽相应键盘按钮操作
Mar 10 Javascript
Javascript中拼接大量字符串的方法
Feb 05 Javascript
javascript实现倒计时(精确到秒)
Jun 26 Javascript
微信小程序 获取session_key和openid的实例
Aug 17 Javascript
vue和webpack打包项目相对路径修改的方法
Jun 15 Javascript
vue 实现单选框设置默认选中值
Nov 07 Javascript
jQuery使用ajax传递json对象到服务端及contentType的用法示例
Mar 12 jQuery
浅谈Vue的computed计算属性
Mar 21 Vue.js
vue.js 使用原生js实现轮播图
Apr 26 Vue.js
原生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
PHP中使用asort进行中文排序失效的问题处理
2014/08/18 PHP
php正则提取html图片(img)src地址与任意属性的方法
2017/02/08 PHP
JS backgroundImage控制
2009/05/19 Javascript
js实现三张图(文)片一起切换的banner焦点图
2015/08/25 Javascript
javascript-解决mongoose数据查询的异步操作
2016/12/22 Javascript
fullCalendar中文API官方文档
2017/02/07 Javascript
jQuery分页插件jquery.pagination.js使用方法解析
2017/02/09 Javascript
javascript深拷贝和浅拷贝详解
2017/02/14 Javascript
vue2.0 路由模式mode=&quot;history&quot;的作用
2018/10/18 Javascript
微信小程序在线客服自动回复功能(基于node)
2019/07/03 Javascript
JavaScript 常见的继承方式汇总
2020/09/17 Javascript
python判断给定的字符串是否是有效日期的方法
2015/05/13 Python
python集合用法实例分析
2015/05/30 Python
python使用requests模块实现爬取电影天堂最新电影信息
2019/04/03 Python
python字典一键多值实例代码分享
2019/06/14 Python
python 实现创建文件夹和创建日志文件的方法
2019/07/07 Python
Flask框架单例模式实现方法详解
2019/07/31 Python
python字符串常用方法及文件简单读写的操作方法
2020/03/04 Python
Python unittest如何生成HTMLTestRunner模块
2020/09/08 Python
Python爬虫开发与项目实战
2020/12/16 Python
Python基础进阶之海量表情包多线程爬虫功能的实现
2020/12/17 Python
使paramiko库执行命令时在给定的时间强制退出功能的实现
2021/03/03 Python
借助HTML5 Canvas来绘制三角形和矩形等多边形的方法
2016/03/14 HTML / CSS
美国最受欢迎的度假租赁网站:VRBO
2016/08/02 全球购物
德国PC硬件网站:CASEKING
2016/10/20 全球购物
英文版区域经理求职信
2013/10/23 职场文书
数控专业个人求职信范例
2013/11/29 职场文书
致短跑运动员广播稿
2014/01/09 职场文书
《罗布泊,消逝的仙湖》教学反思
2014/03/01 职场文书
个人贷款担保书
2014/04/01 职场文书
合伙经营协议书范本
2014/04/18 职场文书
劳动保障个人工作总结
2015/03/04 职场文书
教师远程培训心得体会
2016/01/09 职场文书
个人道歉信大全
2019/04/11 职场文书
导游词之阆中古城
2019/12/23 职场文书
业余无线电通联Q语
2022/02/18 无线电