欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

domReady的實(shí)現(xiàn)案例

 更新時(shí)間:2016年11月23日 09:53:32   投稿:jingxian  
下面小編就為大家?guī)硪黄猟omReady的實(shí)現(xiàn)案例。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧

我們都知道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)文章

最新評論