日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
原生JS怎么實現(xiàn)DOM加載完成馬上執(zhí)行JS代碼的方法-創(chuàng)新互聯(lián)

小編給大家分享一下原生JS怎么實現(xiàn)DOM加載完成馬上執(zhí)行JS代碼的方法,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

創(chuàng)新互聯(lián)堅持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:成都網(wǎng)站制作、網(wǎng)站建設(shè)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時代的饒陽網(wǎng)站設(shè)計、移動媒體設(shè)計的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!

JS是什么

JS是JavaScript的簡稱,它是一種直譯式的腳本語言,其解釋器被稱為JavaScript引擎,是瀏覽器的一部分,主要用于web的開發(fā),可以給網(wǎng)站添加各種各樣的動態(tài)效果,讓網(wǎng)頁更加美觀。

用原生JS我們經(jīng)常使用window.onload事件來加載頁面。但是window.onload是在頁面元素都加載完畢后才執(zhí)行,如果頁面內(nèi)有大的圖片的話,會在頁面展現(xiàn)后好久時間后才執(zhí)行。所以有時我們需要在DOM載入時馬上執(zhí)行一些函數(shù)。jQuery提供了document.ready方法用來代替window.onload。但又不愿意僅為了這一個需求而引入整個JQuery庫,于是就把jQuery的方法提取出來,單獨使用了。

如果只需要對DOM進行操作,那么這時就沒必要等到頁面全部加載了。Firefox有DOMContentLoaded事件可以輕松解決,可惜的就是IE沒有。

MSDN關(guān)于JSCRIPT的一個方法有段不起眼的話,當(dāng)頁面DOM未加載完成時,調(diào)用doScroll方法時,會產(chǎn)生異常。那么我們反過來用,如果不異常,那么就是頁面DOM加載完畢了。所以 對于Mozilla & Opera 瀏覽器,在dom樹載入后有現(xiàn)成的 DOMContentLoaded 事件。對于Safari 瀏覽器,有document.onreadystatechange事件,當(dāng)該觸發(fā)時,如果 document.readyState=complete時,可視為dom樹已經(jīng)載入。

對于ie,當(dāng)在iframe內(nèi)時,同樣有document.onreadystatechange事件,對于ie在非iframe內(nèi)時,只有不斷地通過能否執(zhí)行doScroll判斷dom是否加載完畢。

在本例中每間隔5毫秒嘗試去執(zhí)行 document.documentElement.doScroll(‘left')。在ie8下,貌視非iframe窗口也會有 document.onreadystatechange事件,另外也可以在構(gòu)建自己的框架時使用此函數(shù)。

(function(){
  var isReady=false; //判斷onDOMReady方法是否已經(jīng)被執(zhí)行過
  var readyList= [];//把需要執(zhí)行的方法先暫存在這個數(shù)組里
  var timer;//定時器句柄
 
  ready=function(fn)
  {
   if (isReady )
    fn.call( document);
   else
    readyList.push( function() { return fn.call(this);});
   return this;
  }
 
  var onDOMReady=function(){
   for(var i=0;i< readyList.length;i++)
   {
    readyList[i].apply(document);
   }
   readyList = null;
  }
 
  var bindReady = function(evt)
  {
   if(isReady) return;
   isReady=true;
   onDOMReady.call(window);
   if(document.removeEventListener)
   {
    document.removeEventListener("DOMContentLoaded", bindReady, false);
   }
   else if(document.attachEvent)
   {
    document.detachEvent("onreadystatechange", bindReady);
    if(window == window.top){
     clearInterval(timer);//事件發(fā)生后清除定時器
     timer = null;
    }
   }
  };
 
  if(document.addEventListener){
   document.addEventListener("DOMContentLoaded", bindReady, false);
  }
  else if(document.attachEvent)//非最頂級父窗口
 
  {
   document.attachEvent("onreadystatechange", function(){
    if((/loaded|complete/).test(document.readyState))
    bindReady();
   });
 
  if(window == window.top)//在應(yīng)用有frameset或者iframe的頁面時,parent是父窗口,top是最頂級父窗口(有的窗口中套了好幾層frameset或者iframe)
  {
   timer = setInterval(function(){
    try
    {
     isReady||document.documentElement.doScroll('left');//在IE下用能否執(zhí)行doScroll判斷 dom是否加載完畢
    }
    catch(e)
    {
     return;
    }
    bindReady();
   },5);
  }
  }
 })();

下面是使用方法:

 ready(dosomething);//dosomething為已存在的函數(shù)
 //也可以通過閉包來使用
 ready(function(){
  //這里是邏輯代碼
 });

以上是“原生JS怎么實現(xiàn)DOM加載完成馬上執(zhí)行JS代碼的方法”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計公司行業(yè)資訊頻道!

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機、免備案服務(wù)器”等云主機租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。


網(wǎng)頁名稱:原生JS怎么實現(xiàn)DOM加載完成馬上執(zhí)行JS代碼的方法-創(chuàng)新互聯(lián)
當(dāng)前地址:http://www.dlmjj.cn/article/cshcie.html