时间:2021-05-25
具体出现的情况是这样的:
在页面还没有完全加载的情况下,鼠标点击触发了一个生成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>
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
最近经常要处理控件问题,ie6+可以直接Internet选项,程序中看到已经安装的控件以及版本号等信息,万恶的ie6确看到不到控件的具体版本信息。在如果你是IE
令人崩溃的IE6问题再次出现,打开某个页面时,弹出提示框“InternetExplorer无法打开Internet站点...已终止操作”。查了一下资料,感觉“因
最近经常要处理控件问题,ie6+可以直接Internet选项,程序中看到已经安装的控件以及版本号等信息,万恶的ie6确看到不到控件的具体版本信息。在如果你是IE
IE6下,JSP中链接问题:functionbtnHome_onClick(){window.open("com.mcl.common.main.InitHom
IE6:复制代码代码如下:window.opener=null;window.close();IE7:复制代码代码如下:window.open('','_sel