首頁 > web前端 > js教程 > 主體

domReady的實作案例

高洛峰
發布: 2017-01-04 16:00:51
原創
1330 人瀏覽過

我們都知道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的DOMContentLoadeded -> 觸發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的實作案例就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持PHP中文網。

更多domReady的實現案例相關文章請關注PHP中文網!


相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板