在IE6下發(fā)生Internet Explorer cannot open the Internet site錯誤
更新時間:2010年06月21日 14:54:39 作者:
最近在IE6下面時常會發(fā)生“Internet Explorer cannot open the Internet site ”錯誤。
具體出現(xiàn)的情況是這樣的:
在頁面還沒有完全加載的情況下,鼠標點擊觸發(fā)了一個生成iFrame的腳本事件。
先是想到,將腳本事件,在頁面加載完全后,再動態(tài)添加到觸發(fā)的位置,這樣,頁面加載完全之前,這里是不會有腳本事件的,自然也不會報錯。
以上辦法有些被動,于是去參看生成iframe的腳本。
正常的頁面結構是
<body>
<form>
........
</form>
</body>
生成iframe的腳本是:
function CreateiFrame(){
var objBody = document.getElementsByTagName("body").item(0);
var objiFrame = document.createElement("iframe");
objBody.appendChild(objiFrame);
}
appendChild() 方法,在節(jié)點的子節(jié)點列表末添加新的子節(jié)點。所以創(chuàng)建iframe后的DOM為:
<body>
<form>
........
</form>
<iframe>
........
</iframe>
</body>
因為是在<form>還沒有加載完全的情況下,創(chuàng)建了<iframe>,所以在IE6下就出現(xiàn)了頁面錯誤。
相信在看到這里的時候,已經發(fā)現(xiàn)了解決的辦法:將<iframe>創(chuàng)建在<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() 方法,在節(jié)點的子節(jié)點列表任意位置插入新的節(jié)點。
insertBefore有2個參數(shù)可以設置,第一個是和appendChild相同的;第二可以為null,效果等同于insertBefore() 方法,也可以為指定需要在哪個子節(jié)點之前插入新子節(jié)點。
<body>
<iframe>
........
</iframe>
<form id“form1”>
........
</form>
</body>
在頁面還沒有完全加載的情況下,鼠標點擊觸發(fā)了一個生成iFrame的腳本事件。
先是想到,將腳本事件,在頁面加載完全后,再動態(tài)添加到觸發(fā)的位置,這樣,頁面加載完全之前,這里是不會有腳本事件的,自然也不會報錯。
以上辦法有些被動,于是去參看生成iframe的腳本。
正常的頁面結構是
復制代碼 代碼如下:
<body>
<form>
........
</form>
</body>
生成iframe的腳本是:
復制代碼 代碼如下:
function CreateiFrame(){
var objBody = document.getElementsByTagName("body").item(0);
var objiFrame = document.createElement("iframe");
objBody.appendChild(objiFrame);
}
appendChild() 方法,在節(jié)點的子節(jié)點列表末添加新的子節(jié)點。所以創(chuàng)建iframe后的DOM為:
復制代碼 代碼如下:
<body>
<form>
........
</form>
<iframe>
........
</iframe>
</body>
因為是在<form>還沒有加載完全的情況下,創(chuàng)建了<iframe>,所以在IE6下就出現(xiàn)了頁面錯誤。
相信在看到這里的時候,已經發(fā)現(xiàn)了解決的辦法:將<iframe>創(chuàng)建在<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() 方法,在節(jié)點的子節(jié)點列表任意位置插入新的節(jié)點。
insertBefore有2個參數(shù)可以設置,第一個是和appendChild相同的;第二可以為null,效果等同于insertBefore() 方法,也可以為指定需要在哪個子節(jié)點之前插入新子節(jié)點。
復制代碼 代碼如下:
<body>
<iframe>
........
</iframe>
<form id“form1”>
........
</form>
</body>
您可能感興趣的文章:
相關文章
JavaScript實現(xiàn)的級聯(lián)算法示例【省市二級聯(lián)動功能】
這篇文章主要介紹了JavaScript實現(xiàn)的級聯(lián)算法,結合省市二級聯(lián)動下拉菜單功能實例分析了javascript事件響應與元素動態(tài)操作實現(xiàn)級聯(lián)算法的相關技巧,需要的朋友可以參考下2018-12-12區(qū)分中英文字符的兩種方法(正則和charCodeAt())
最近在為項目寫登錄注冊系列頁面, 表單驗證無疑是不可缺少的部分, 在這個jQ插件滿天飛的web年代, 表單驗證倒也不是難事. 但再好的插件, 也并不能做到十全十美2010-11-11