时间:2021-07-01 10:21:17 帮助过:12人阅读
<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>