博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Chrome和IE中使用window.open函数
阅读量:6330 次
发布时间:2019-06-22

本文共 1715 字,大约阅读时间需要 5 分钟。

做前端开发的人员经常回遇到使用windows.open这个函数来打开一个新的网页窗口,使用这个函数的时候有些需要注意的地方,在Chrome和IE下该函数还是有一些细节性的区别。 以下是我在项目中使用的代码(大概用法):

Download.html的代码如下:

    Test Window    
View Code

父窗口中的Javascript代码如下:

var promptWnd=window.open("Download.html);var divHtml=[];divHtml.push('
This is first divsection
');divHtml.push('
This is second divsection
');promptWnd.document.getElementById("main_body").innerHTML = divHtml.join('');
View Code

以上这段Javascript代码在IE中运行正常(至少我测试是正常运行的),但是在Chrome中使用就有问题了,在Chrome中子窗口弹出来了,但是无法将div添加到子窗口中。

使用alert(promptWnd.document.getElementById("main_body")),发现输出的为null。

因此,我大胆的推测,window.open函数在IE和Chrome中实现方式是不一样的,IE中是同步执行的,也就是说在IE中子窗口的Dom元素加载完成才返回;而在Chrome中则是 异步执行的,也就是说Chrome不会等子窗口中的Dom元素加载完才返回。

根据这种推测,通过返回的promptWnd句柄是不可以操作子窗口的Dom元素的[因为子窗口的Dom 元素没有加载完成]。

我的解决方案如下[使用setInterval函数检查Dom元素是否加载成功],代码如下:

var interval=null;var promptWnd=window.open("Download.html);var divHtml=[];divHtml.push('
This is first divsection
');divHtml.push('
This is second divsection
');function checkDomReady() { var result = promptWnd.document.getElementById("main_body") == null ? false : true; if (result == true) { clearInterval(interval); promptWnd.document.getElementById("main_body").innerHTML = divHtml.join(''); }};(function checkWndReady() { if (promptWnd.document.getElementById("main_body") == null) { checkDomReady(); interval = setInterval(checkDomReady, 1000); } else { promptWnd.document.getElementById("main_body").innerHTML = divHtml.join(''); }})();
View Code

经过测试以上代码可以再IE和Chrome下按照指定的需求正常运行。独乐乐不如众乐乐,希望以上解决思路对读者有所帮助!

转载于:https://www.cnblogs.com/chengbing2011/p/4224588.html

你可能感兴趣的文章
对事件处理的错误使用
查看>>
最大熵模型(二)朗格朗日函数
查看>>
深入了解setInterval方法
查看>>
html img Src base64 图片显示
查看>>
[Spring学习笔记 7 ] Spring中的数据库支持 RowMapper,JdbcDaoSupport 和 事务处理Transaction...
查看>>
FFMPEG中关于ts流的时长估计的实现(转)
查看>>
Java第三次作业
查看>>
【HDOJ 3652】B-number
查看>>
android代码混淆笔记
查看>>
Codeforces Round #423 (Div. 2, rated, based on VK Cup Finals) C. String Reconstruction 并查集
查看>>
BMP文件的读取与显示
查看>>
Flash文字效果
查看>>
各种排序算法总结篇(高速/堆/希尔/归并)
查看>>
使用c#訪问Access数据库时,提示找不到可安装的 ISAM
查看>>
Highcharts X轴纵向显示
查看>>
windows 注册表讲解
查看>>
【算法】论平衡二叉树(AVL)的正确种植方法
查看>>
基于DDD的现代ASP.NET开发框架--ABP系列之1、ABP总体介绍
查看>>
【原】东拼西凑PBR(1):PBR基础
查看>>
react 从零开始搭建开发环境
查看>>