在IE6下发生Internet Explorer cannot open the Internet site错误

本文探讨了在IE6浏览器中加载iframe时遇到的问题及解决方法。通过调整DOM结构顺序,使用insertBefore方法而非appendChild,确保iframe在form标签之前加载,有效避免了因页面未完全加载引起的错误。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近在IE6下面时常会发生“Internet Explorer cannot open the Internet site ”错误。

 

具体出现的情况是这样的:

  在页面还没有完全加载的情况下,鼠标点击触发了一个生成iFrame的脚本事件。

先是想到,将脚本事件,在页面加载完全后,再动态添加到触发的位置,这样,页面加载完全之前,这里是不会有脚本事件的,自然也不会报错。

  以上办法有些被动,于是去参看生成iframe的脚本。

  正常的页面结构是

 

 
  
1 < body >
2 < form >
3 ........
4 </ form >
5   </ body >

 

生成iframe的脚本是:

 

 
  
1 function CreateiFrame(){
2    var objBody = document.getElementsByTagName( " body " ).item( 0 );
3    var objiFrame = document.createElement( " iframe " );
4   objBody.appendChild(objiFrame);
5 }

appendChild() 方法,在节点的子节点列表末添加新的子节点。所以创建iframe后的DOM为:

 

 
  
1 < body >
2 < form >
3 ........
4 </ form >
5 < iframe >
6 ........
7 </ iframe >
8 </ body >

因为是在<form>还没有加载完全的情况下,创建了<iframe>,所以在IE6下就出现了页面错误。

相信在看到这里的时候,已经发现了解决的办法:将<iframe>创建在<form>之前的话,就没有问题了!

那么,我们就需要用到另外一个添加元素的方法 insertBefore():

 

 
   
1 function CreateiFrame(){
2 var objBody = document.getElementsByTagName( " body " ).item( 0 );
3 var objiFrame = document.createElement( " iframe " );
4 objBody.insertBefore(objiFrame,document.getElementById( " form1 " )); // form1为form的id
5 }

insertBefore() 方法,在节点的子节点列表任意位置插入新的节点。

insertBefore有2个参数可以设置,第一个是和appendChild相同的;第二可以为null,效果等同于insertBefore() 方法,也可以为指定需要在哪个子节点之前插入新子节点。

 

 
  
1 < body >
2 < iframe >
3 ........
4 </ iframe >
5 < form id“form1” >
6 ........
7 </ form >
8 </ body >

 

 

 

--by 泡沫的幻想

 

转载于:https://www.cnblogs.com/tc_Sky/archive/2010/06/21/1761661.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值