domReady的實(shí)現(xiàn)案例
我們都知道JQ的 $(document).ready(fn) 方法??梢栽陧撁鏈?zhǔn)備就緒后才執(zhí)行腳本,該方法相比傳統(tǒng)的window.onload 事件,它的優(yōu)勢體現(xiàn)于onload事件是需要等到頁面中所有資源都加載完畢后才會(huì)觸發(fā),而JQ的ready方法則會(huì)判斷DOM樹是否構(gòu)建完畢。
onload相比較onreadystate事件的區(qū)別是,onreadystatechange事件是IE獨(dú)有的,并且在IE11之后不再支持,該事件是IE瀏覽器為特定的需要判斷資源加載的DOM元素指定的事件。
支持onreadystatechange事件的DOM元素必然有一個(gè)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事件。
從這個(gè)流程,我們可以看出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(); //刪除第一個(gè)數(shù)組元素 } flag = true; removeEvent(); } }, readyState = function(){ if(document.readyState == 'complete'){ handle(); } }, DOMContentloaded=function(){ if(document.readyState == 'complete'){ setTimeout(handle); // setTimeout 會(huì)使用最短時(shí)間,該時(shí)間不同系統(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的時(shí)候,它會(huì)等待iframe加載完畢才會(huì)觸發(fā)。 if(self === self.top){ // 當(dāng)頁面不在iframe中則使用此種方式檢測doScroll方法是否可用。如果再iframe中則用onreadstatechange事件進(jìn)行判斷。 (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的實(shí)現(xiàn)案例就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
簡單實(shí)現(xiàn)jQuery進(jìn)度條輪播實(shí)例代碼
這篇文章主要為大家詳細(xì)介紹了簡單實(shí)現(xiàn)jQuery進(jìn)度條輪播實(shí)例代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-06-06JQuery Mobile實(shí)現(xiàn)導(dǎo)航欄和頁腳
導(dǎo)航欄由一組水平排列的鏈接構(gòu)成,通常位于頁眉或頁腳內(nèi)部。本文給大家介紹JQuery Mobile實(shí)現(xiàn)導(dǎo)航欄和頁腳的相關(guān)知識,需要的朋友參考下吧2016-03-03jQuery插件zTree實(shí)現(xiàn)刪除樹子節(jié)點(diǎn)的方法示例
這篇文章主要介紹了jQuery插件zTree實(shí)現(xiàn)刪除樹子節(jié)點(diǎn)的方法,結(jié)合實(shí)例形式分析了jQuery樹形插件zTree針對節(jié)點(diǎn)的遍歷與刪除操作相關(guān)技巧,需要的朋友可以參考下2017-03-03jQuery實(shí)現(xiàn)可以擴(kuò)展的日歷
這篇文章主要為大家詳細(xì)介紹了jQuery實(shí)現(xiàn)可以擴(kuò)展的日歷,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-12-12jquery實(shí)現(xiàn)將獲取的顏色值轉(zhuǎn)換為十六進(jìn)制形式的方法
這篇文章主要介紹了jquery實(shí)現(xiàn)將獲取的顏色值轉(zhuǎn)換為十六進(jìn)制形式的方法,包含了完整的實(shí)例與關(guān)鍵代碼的注釋說明,并附帶了所需知識點(diǎn)的參考文章地址,具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2014-12-12JQuery使用屬性addClass、removeClass和toggleClass實(shí)現(xiàn)增加和刪除類操作示例
這篇文章主要介紹了JQuery使用屬性addClass、removeClass和toggleClass實(shí)現(xiàn)增加和刪除類操作,涉及jquery事件響應(yīng)及頁面元素屬性動(dòng)態(tài)操作相關(guān)使用技巧,需要的朋友可以參考下2019-11-11