JS兼容所有瀏覽器的DOMContentLoaded事件怎么用

小編給大家分享一下JS兼容所有瀏覽器的DOMContentLoaded事件怎么用,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

桂林ssl適用于網(wǎng)站、小程序/APP、API接口等需要進(jìn)行數(shù)據(jù)傳輸應(yīng)用場(chǎng)景,ssl證書(shū)未來(lái)市場(chǎng)廣闊!成為創(chuàng)新互聯(lián)建站的ssl證書(shū)銷(xiāo)售渠道,可以享受市場(chǎng)價(jià)格4-6折優(yōu)惠!如果有意向歡迎電話(huà)聯(lián)系或者加微信:18980820575(備注:SSL證書(shū)合作)期待與您的合作!

實(shí)現(xiàn)過(guò)程介紹:

標(biāo)準(zhǔn)瀏覽器中,使用DOMContentLoaded事件即可實(shí)現(xiàn)我們的要求,注冊(cè)事件處理函數(shù)也極為簡(jiǎn)單。

代碼如下:

addEventListener(‘DOMContentLoaded',fn,false)

但I(xiàn)E8和IE8以下瀏覽器并不支持DOMContentLoaded事件,所以還需要另辟蹊徑來(lái)解決此問(wèn)題。

可能很多朋友認(rèn)為根據(jù)document.onreadystatechange事件的document.readyState狀態(tài)是否等于complete來(lái)判斷dom結(jié)構(gòu)是否加載完畢,但經(jīng)過(guò)測(cè)試并不能完成任務(wù),如果頁(yè)面使用iframe引入子頁(yè)面,會(huì)有問(wèn)題。

解決方案如下:

低版本IE瀏覽器特有的doScroll方法,當(dāng)dom結(jié)構(gòu)沒(méi)有加載完成時(shí),調(diào)用此方法會(huì)報(bào)錯(cuò),于是可以通過(guò)定時(shí)器函數(shù)不斷的調(diào)用此方法,并結(jié)合try catch語(yǔ)句來(lái)實(shí)現(xiàn)判斷功能,代碼如下:

eventQueue = [];
isReady = false;
isBind = false;
function domReady(fn){
 if(isReady){
  fn.call(window);
 }
 else{
  eventQueue.push(fn);
 };
 bindReady();
};
function bindReady(){
 if(isReady) return;
  if(isBind) return;
  isBind=true;
  if(window.addEventListener){
   document.addEventListener('DOMContentLoaded',execFn,false);
  }
  else if(window.attachEvent){
   doScroll();
  };
};
function doScroll(){
 try{
  document.documentElement.doScroll('left');
 }
 catch(error){
  return setTimeout(doScroll,20);
 };
 execFn();
};
function execFn(){
 if(!isReady){
  isReady=true;
  for(var index=0;i<eventQueue.length;index++){
   eventQueue[index].call(window);
  };
  eventQueue = [];
 };
};
domReady(function(){
 //code
});
domReady(function(){
 //code
});

代碼實(shí)現(xiàn)了兼容所有瀏覽器的DOMContentLoaded效果,下面介紹一下它的實(shí)現(xiàn)過(guò)程。

一.代碼注釋:

(1).eventQueue = [],聲明一個(gè)空數(shù)組,用來(lái)要執(zhí)行的函數(shù)隊(duì)列。

(2).isReady = false,聲明一個(gè)變量并賦初值為false,如果為true則表示dom已經(jīng)加載完畢。

(3).isBind = false,聲明一個(gè)變量并賦初值為false,如果為true,則表示時(shí)間處理函數(shù)綁定完畢。

(4).function domReady(fn){},此函數(shù)實(shí)現(xiàn)了等dom加載完畢再去執(zhí)行fn函數(shù)的功能。

(5).if(isReady){fn.call(window);},如果變量值為true,則直接執(zhí)行函數(shù)。

(6).else{eventQueue.push(fn);},將要執(zhí)行的函數(shù)加入數(shù)組中。

(7).bindReady(),此函數(shù)可以實(shí)現(xiàn)注冊(cè)事件處理函數(shù)。

(8).if(isReady) return,如果等于true,直接跳出函數(shù),這個(gè)時(shí)候fn函數(shù)已經(jīng)被執(zhí)行。

(9).if(isBind) return,如果已經(jīng)注冊(cè)的話(huà),同樣無(wú)需進(jìn)行第二次。

(10).isBind=true,將變量的值修改為true。

(11).if(window.addEventListener){document.addEventListener('DOMContentLoaded',execFn,false);},如果是標(biāo)準(zhǔn)瀏覽器則使用addEventListener注冊(cè)事件處理函數(shù)。

(12).else if(window.attachEvent){doScroll();},如果IE8及IE8以下瀏覽器,調(diào)用doScroll方法實(shí)現(xiàn)此效果。

(13).function doScroll(){},此函數(shù)可以使用利用定時(shí)器函數(shù)不斷的調(diào)用doScroll()函數(shù),如果報(bào)錯(cuò),則繼續(xù)調(diào)用,否則的話(huà),也就是dom結(jié)構(gòu)加載完畢,于是就執(zhí)行相關(guān)函數(shù)。

(14).function execFn(){},此函數(shù)可以從數(shù)組中取出要執(zhí)行的函數(shù),然后執(zhí)行,并最后將數(shù)組清空。

以上是“JS兼容所有瀏覽器的DOMContentLoaded事件怎么用”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!

文章名稱(chēng):JS兼容所有瀏覽器的DOMContentLoaded事件怎么用
當(dāng)前地址:http://muchs.cn/article44/jehiee.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站改版App開(kāi)發(fā)、定制網(wǎng)站、網(wǎng)站導(dǎo)航、軟件開(kāi)發(fā)、建站公司

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話(huà):028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

網(wǎng)站托管運(yùn)營(yíng)