domReady的實現(xiàn)案例
我們都知道JQ的 $(document).ready(fn) 方法??梢栽陧撁鏈蕚渚途w后才執(zhí)行腳本,該方法相比傳統(tǒng)的window.onload 事件,它的優(yōu)勢體現(xiàn)于onload事件是需要等到頁面中所有資源都加載完畢后才會觸發(fā),而JQ的ready方法則會判斷DOM樹是否構(gòu)建完畢。
onload相比較onreadystate事件的區(qū)別是,onreadystatechange事件是IE獨有的,并且在IE11之后不再支持,該事件是IE瀏覽器為特定的需要判斷資源加載的DOM元素指定的事件。
支持onreadystatechange事件的DOM元素必然有一個readyState屬性,該屬性的返回值,用于說明資源的加載情況。
一般而言,onreadystatechange事件更多用于Iframe的加載判斷。
最后我們需要了解的是當(dāng)頁面包含iframe后,DOM樹的生成,以及DOMContentLoaded事件的觸發(fā),onload事件的觸發(fā),其流程對于IE非IE是不同的。
一般來說:
IE :解析index頁面 -> 解析iframe頁面 -> 觸發(fā)iframe的DOMContentLoaded事件 -> 觸發(fā)iframe頁面 onload事件 -> 觸發(fā)Index頁面的DOMContentLoaded事件 -> 觸發(fā)index頁面的onload事件。
!IE:解析index頁面 -> 觸發(fā)index頁面的DOMContentLoaded事件 -> 解析iframe頁面 -> 觸發(fā)iframe頁面的DOMContentLoaded事件 -> 觸發(fā)iframe的onload事件 -> 觸發(fā)index頁面的onload事件。
從這個流程,我們可以看出IE中,必須等待當(dāng)前頁面的iframe加載解析完畢,當(dāng)前頁面才能加載解析完畢,而在非IE中,iframe的加載與解析對當(dāng)前頁面來言更多的是異步執(zhí)行。
下面是具體的代碼:
(function(win){
'use strict';
var document = win.document,
readList = [], // 等待執(zhí)行的函數(shù)堆棧
flag = false;
var removeEvent = function(){
if(document.addEventListenner){
window.removeEventListenner('load',handle,false);
}else if(document.attachEvent){
window.detachEvent('onload',handle)
document.detachEvent('onreadystatechange',readyState);
}else{
window.onload = null;
}
},
handle = function(){
if(!flag){
while(readList.length){
readList[0].call(); //執(zhí)行函數(shù)
readList.shift(); //刪除第一個數(shù)組元素
}
flag = true;
removeEvent();
}
},
readyState = function(){
if(document.readyState == 'complete'){
handle();
}
},
DOMContentloaded=function(){
if(document.readyState == 'complete'){
setTimeout(handle); // setTimeout 會使用最短時間,該時間不同系統(tǒng)并不一樣。
}else if(document.addEventListenner){
document.addEventListenner('DOMContentLoaded',fn,false);
window.addEventListenner('load',handle,false);
}else if(document.attachEvent){
window.attachEvent('onload',handle);
document.attachEvent('onreadystatechange',readyState); //onreadystatechange 事件在頁面中含有iframe的時候,它會等待iframe加載完畢才會觸發(fā)。
if(self === self.top){ // 當(dāng)頁面不在iframe中則使用此種方式檢測doScroll方法是否可用。如果再iframe中則用onreadstatechange事件進行判斷。
(function(){
try{
document.documentElement.doScroll('left');
}catch(e){
setTimeout(arguments.callee,50); //arguments.callee 是對當(dāng)前函數(shù)的引用。
return ;
}
handle();
}());
}
}else{
window.onload = handle;
}
},
ready = function(fn){
readList.push(fn); // 加入待處理的堆棧中。
DOMContentloaded();
};
win.domReady = ready;
}(window));
代碼調(diào)用:
domReady(function(){
document.getElementById('box').innerHTML = (new Date().getTime() - date)/1000;
});
以上這篇domReady的實現(xiàn)案例就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
jQueryMobile之窗體長內(nèi)容的缺陷與解決方法實例分析
這篇文章主要介紹了jQueryMobile之窗體長內(nèi)容的缺陷與解決方法,結(jié)合具體實例形式分析了jQueryMobile底部懸浮層遮擋情況下的解決方法,非常簡單實用,需要的朋友可以參考下2017-09-09
Jquery?on("click")方法綁定事件后執(zhí)行多次的解決方法
這篇文章主要給大家介紹了關(guān)于Jquery?on("click")方法綁定事件后執(zhí)行多次的解決方法,文章通過實例代碼以及圖文介紹的非常詳細,對大家學(xué)習(xí)或者使用jQuery具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2023-06-06
jQuery添加/改變/移除CSS類及判斷是否已經(jīng)存在CSS
正如標題所言會用到removeClass移除CSS類、addClass添加CSS類、toggleClass添加或者移除CSS類,hasClass判斷是否已經(jīng)存在CSS2014-08-08
jQuery數(shù)據(jù)緩存功能的實現(xiàn)思路及簡單模擬
jQuery緩存系統(tǒng)不僅運用于DOM元素,動畫、事件等都有用到這個緩存系統(tǒng)2013-05-05

