具体出现的情况是这样的:
在页面还没有完全加载的情况下,鼠标点击触发了一个生成iframe的脚本事件。
先是想到,将脚本事件,在页面加载完全后,再动态添加到触发的位置,这样,页面加载完全之前,这里是不会有脚本事件的,自然也不会报错。
以上办法有些被动,于是去参看生成iframe的脚本。
正常的页面结构是
复制代码 代码如下:
........
生成iframe的脚本是:
复制代码 代码如下:
function createiframe(){
var objbody = document.getelementsbytagname(body).item(0);
var objiframe = document.createelement(iframe);
objbody.appendchild(objiframe);
}
appendchild() 方法,在节点的子节点列表末添加新的子节点。所以创建iframe后的dom为:
复制代码 代码如下:
........
........
因为是在还没有加载完全的情况下,创建了,所以在ie6下就出现了页面错误。
相信在看到这里的时候,已经发现了解决的办法:将创建在之前的话,就没有问题了!
那么,我们就需要用到另外一个添加元素的方法 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() 方法,也可以为指定需要在哪个子节点之前插入新子节点。
复制代码 代码如下:
........
........
