在IE6下发生Internet Explorer cannot open the Internet site错误_Javascript教程-查字典教程网
在IE6下发生Internet Explorer cannot open the Internet site错误
在IE6下发生Internet Explorer cannot open the Internet site错误
发布时间:2016-12-30 来源:查字典编辑
摘要:具体出现的情况是这样的:在页面还没有完全加载的情况下,鼠标点击触发了一个生成iFrame的脚本事件。先是想到,将脚本事件,在页面加载完全后,...

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

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

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

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

正常的页面结构是

复制代码 代码如下:

<body>

<form>

........

</form>

</body>

生成iframe的脚本是:

复制代码 代码如下:

function CreateiFrame(){

var objBody = document.getElementsByTagName("body").item(0);

var objiFrame = document.createElement("iframe");

objBody.appendChild(objiFrame);

}

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

复制代码 代码如下:

<body>

<form>

........

</form>

<iframe>

........

</iframe>

</body>

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

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

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

复制代码 代码如下:

function CreateiFrame(){

var objBody = document.getElementsByTagName("body").item(0);

var objiFrame = document.createElement("iframe");

objBody.insertBefore(objiFrame,document.getElementById("form1")); //form1为form的id

}

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

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

复制代码 代码如下:

<body>

<iframe>

........

</iframe>

<form id“form1”>

........

</form>

</body>

相关阅读
推荐文章
猜你喜欢
附近的人在看
推荐阅读
拓展阅读
  • 大家都在看
  • 小编推荐
  • 猜你喜欢
  • 最新Javascript教程学习
    热门Javascript教程学习
    编程开发子分类