|
一、Mozilla 提供了一個非公開的(undocumented)函數:
復制代碼 代碼如下:
// for Mozilla browsers
if (document.addEventListener) {
document.addEventListener("DOMContentLoaded", init, false);
}
二、對于 IE 瀏覽器,可以使用IE特有的 defer 屬性:
復制代碼 代碼如下:
<script defer type="text/Javascript">
alert("DOM 加載完畢!")
</script>
具有defer屬性的腳本塊會在DOM 加載完畢后執行。
非IE瀏覽器會忽略 defer 而直接執行 script 代碼,因此,你可以有兩種辦法來屏蔽非IE瀏覽器執行這段針對IE的代碼:
1.條件注釋
復制代碼 代碼如下:
<!--[if IE]>
<script defer type="text/Javascript">
alert("DOM 加載完畢!")
</script>
<![endif]-->
2.條件編輯
復制代碼 代碼如下:
<script defer type="text/Javascript">
// for InterNET Explorer
/*@cc_on @*/
/*@if (@_win32)
alert("DOM 加載完畢!");
/*@end @*/
</script>
三、對于Safari,這里有一個jQuery的解決方案:
復制代碼 代碼如下:
if (/WebKit/i.test(navigator.userAgent)) { // sniff
var _timer = setInterval(function() {
if (/loaded|complete/.test(document.readyState)) {
clearInterval(_timer);
init(); // call the onload handler
}
}, 10);
}
JavaScript技術:window.onload 加載完畢的問題及解決方案(上),轉載需保留來源!
鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。