日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

jQuery中的ready

發(fā)布時間:2023/12/2 编程问答 54 豆豆
生活随笔 收集整理的這篇文章主要介紹了 jQuery中的ready 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

基于jQuery v1.8.3

在js與DOM交互之前要確保DOM已經(jīng)加載構(gòu)建完成,在jQuery中都是使用 (fn)(document).ready(fn)來確保自己寫的代碼在DOM構(gòu)建完成之后執(zhí)行。
那么jQuery的ready事件內(nèi)部怎么實現(xiàn)的呢?

通過閱讀源碼(line:842 ~ 898)知道jQuery內(nèi)部使用四種判別文檔是否加載完成的事件:

  • DOMContentLoaded 初始的 HTML 文檔被完全加載和解析完成之后,DOMContentLoaded 事件被觸發(fā),而無需等待樣式表、圖像和子框架的完成加載

  • load 一個頁面完全加載之后觸發(fā)

  • readyStateChange 文檔加載狀態(tài)(document.readyState)改變的時候觸發(fā),當document.readyState === ‘complete’ 為 true 表示文檔解析完成。

    readyState可能的值有:

    1. loading 加載2. interactive 互動3. complete 完成
  • doScroll 低版本IE支持的事件,如果調(diào)用不出錯就表示文檔解析完成

  • 部分源碼如下:

    /** *先檢查一下文檔是否加載完成了,如果執(zhí)行這個方法的時候文檔已經(jīng)加載完成還不知道就尷尬了。。。后面注冊的監(jiān)聽文檔是否加載完成的事件都不會被觸發(fā) *因為我們都知道事件的特性就是錯過了就是錯過了 */ if ( document.readyState === "complete" ) {setTimeout( jQuery.ready, 1 ); } else if ( document.addEventListener ) {// 檢測是否支持 DOMContentLoaded,該事件這是H5新加的事件,在DOM結(jié)構(gòu)構(gòu)件完成觸發(fā),不會等待資源的下載如IMG等,所以會比window.onload提前觸發(fā)document.addEventListener( "DOMContentLoaded", DOMContentLoaded, false );// 監(jiān)聽onload事件window.addEventListener( "load", jQuery.ready, false ); } else {// 這里是低版本的IE瀏覽器// 通過attachEvent監(jiān)聽readystatechange和load事件document.attachEvent( "onreadystatechange", DOMContentLoaded );window.attachEvent( "onload", jQuery.ready );// 在頂層不在iframe里面var top = false;try {top = window.frameElement == null && document.documentElement;} catch(e) {}if ( top && top.doScroll ) {(function doScrollCheck() {if ( !jQuery.isReady ) {try {top.doScroll("left");} catch(e) {return setTimeout( doScrollCheck, 50 );}jQuery.ready();}})();}

    通過以上源碼分析,自己來實現(xiàn)一個完整的

    需求:

    確保代碼會在文檔加載完的第一時間被調(diào)用

    可以正確處理多次調(diào)用(調(diào)用多次ready(fn); ready(fn))

    (function(window, undefined){// 任務隊列var PENDING = 'pending',COMPLETE = 'complete',first = true, // 第一次調(diào)用ready方法queue = [],state = PENDING; // pending complatevar obser = {queue: [],fire: function(){while(this.queue.length){this.queue.shift()();}},add: function(fn){this.queue.push(fn);}};function loaded(){// 防止被觸發(fā)多次if(state === COMPLETE) return;if(document.addEventListener){state = COMPLETE;obser.fire();document.removeEventListener('DOMContentLoaded', loaded, false);window.removeEventListener('load', loaded, false);}else if(document.readyState === 'complete'){// 這里必須要是 document.readyState === 'complate' 才行state = COMPLETE;obser.fire();document.detachEvent('DOMContentLoaded', loaded);window.detachEvent('load', loaded);}}function ready(fn){if(first){// 如果是第一次調(diào)用順待要注冊一下事件if(document.readyState === 'complete'){loaded();}else if(document.addEventListener){document.addEventListener('DOMContentLoaded', loaded, false);window.addEventListener('load', loaded, false);}else{// 這里處理IEdocument.attachEvent('onreadystatechange', loaded);window.attachEvent('onload', loaded);}}if(state === COMPLETE){fn();}else{obser.add(fn);}}window.ready = ready; })(window, undefined);// 之后直接調(diào)用ready(fn)即可

    總結(jié)

    以上是生活随笔為你收集整理的jQuery中的ready的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。