我們都知道JQ的 $(document).ready(fn) 方法。可以在頁面准備就緒後才執行腳本,該方法相比傳統的window.onload 事件,它的優勢體現於onload事件是需要等到頁面中所有資源都加載完畢後才會觸發,而JQ的ready方法則會判斷DOM樹是否構建完畢。
onload相比較onreadystate事件的區別是,onreadystatechange事件是IE獨有的,並且在IE11之後不再支持,該事件是IE浏覽器為特定的需要判斷資源加載的DOM元素指定的事件。
支持onreadystatechange事件的DOM元素必然有一個readyState屬性,該屬性的返回值,用於說明資源的加載情況。
一般而言,onreadystatechange事件更多用於Iframe的加載判斷。
最後我們需要了解的是當頁面包含iframe後,DOM樹的生成,以及DOMContentLoaded事件的觸發,onload事件的觸發,其流程對於IE非IE是不同的。
一般來說:
IE :解析index頁面 -> 解析iframe頁面 -> 觸發iframe的DOMContentLoaded事件 -> 觸發iframe頁面 onload事件 -> 觸發Index頁面的DOMContentLoaded事件 -> 觸發index頁面的onload事件。
!IE:解析index頁面 -> 觸發index頁面的DOMContentLoaded事件 -> 解析iframe頁面 -> 觸發iframe頁面的DOMContentLoaded事件 -> 觸發iframe的onload事件 -> 觸發index頁面的onload事件。
從這個流程,我們可以看出IE中,必須等待當前頁面的iframe加載解析完畢,當前頁面才能加載解析完畢,而在非IE中,iframe的加載與解析對當前頁面來言更多的是異步執行。
下面是具體的代碼:
(function(win){ 'use strict'; var document = win.document, readList = [], // 等待執行的函數堆棧 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(); //執行函數 readList.shift(); //刪除第一個數組元素 } flag = true; removeEvent(); } }, readyState = function(){ if(document.readyState == 'complete'){ handle(); } }, DOMContentloaded=function(){ if(document.readyState == 'complete'){ setTimeout(handle); // setTimeout 會使用最短時間,該時間不同系統並不一樣。 }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加載完畢才會觸發。 if(self === self.top){ // 當頁面不在iframe中則使用此種方式檢測doScroll方法是否可用。如果再iframe中則用onreadstatechange事件進行判斷。 (function(){ try{ document.documentElement.doScroll('left'); }catch(e){ setTimeout(arguments.callee,50); //arguments.callee 是對當前函數的引用。 return ; } handle(); }()); } }else{ window.onload = handle; } }, ready = function(fn){ readList.push(fn); // 加入待處理的堆棧中。 DOMContentloaded(); }; win.domReady = ready; }(window));
代碼調用:
domReady(function(){ document.getElementById('box').innerHTML = (new Date().getTime() - date)/1000; });
以上這篇domReady的實現案例就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持。