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

Download.html的代码如下:

<!DOCTYPE html>
<html>
<head>
<title>Test Window</title>
</head>
<body>
<div id='main_body' style="width: 100%; height: 100%"></div>
</body> </html>

父窗口中的Javascript代码如下:

var promptWnd=window.open("Download.html);

var divHtml=[];

divHtml.push('<div>This is first divsection</div>');
divHtml.push('<div>This is second divsection</div>'); promptWnd.document.getElementById("main_body").innerHTML = divHtml.join('');

以上这段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('<div>This is first divsection</div>');
divHtml.push('<div>This is second divsection</div>'); 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('');
} })();

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

最新文章

  1. WebEssentials 在vs2013 update5安装报错的解决方法.
  2. UOJ #58 【WC2013】 糖果公园
  3. 转-利用Oracle审计功能来监测试环境的变化
  4. (LinkedList)2. Add Two Numbers
  5. iOS手势识别的详细使用(拖动,缩放,旋转,点击,手势依赖,自定义手势)
  6. Android中的Surface和SurfaceView
  7. 轻量级的内部测试过程r \\ u0026研发团队
  8. zookeeper(2)-curator
  9. Win7电脑桌面的Administrator图标没了怎么办
  10. hibernate HQL添加语句
  11. ActiveReports报表控件 V13 正式发布,提供在线报表设计和自适应报表布局
  12. FutureTask原理解析
  13. CSAPP:第三章程序的机器级表示2
  14. java 中,如何获取文件的MD5值呢?如何比较两个文件是否完全相同呢?
  15. 『TensorFlow』第十弹_队列&amp;多线程_道路多坎坷
  16. js数组对象--数据格式的转换(字符串,对象的取值与赋值)
  17. 《Linux内核》读书笔记 第十八章
  18. [uart]理解线路规程的作用
  19. jQuery异步请求模拟IE登录网站
  20. mysql循环查询树状数据

热门文章

  1. sass中中文注释报错
  2. 图片上传预览 (URL.createObjectURL)
  3. 字符编码笔记:ASCII,Unicode和UTF-8(转载)
  4. 夕甲甲——孔乙己之C++版
  5. FT部署图
  6. hdoj 1576
  7. 如何查询postgresql+openstreetmap
  8. 计算机网络(8)-----TCP报文段的首部格式
  9. Visro 应用的前端模板工具介绍 -JsRender
  10. Python中setuptools做什么用的?