亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

jQuery的Read()方法代替原生JS詳解

2019-11-19 19:01:13
字體:
來源:轉載
供稿:網友

在jQuery 3.0的版本前, ready經典用法是用一個匿名函數,像這樣:

$(document).ready(function() { // Handler for .ready() called.});

jQuery 3.0 ready() 變化

在jQuery 3.0發布之前,有以下幾種方法稱之為ready方法:

    在document元素上操作: $(document).ready(handler);

    在空元素上操作: $().ready(handler);

    或者直接(即不在一個具體的元素上)操作: $(handler);

上述所有命名的變種在功能上是等價的。無論是哪個元素,在DOM加載完畢之后其指定的處理程序都將會被調用。換句話說,這里的DOM加載完畢并不表示在文檔中的某個具體的元素,比如img元素,加載完畢。相反,這里表示的是整個DOM樹加載完畢。

在jQuery 3.0中,除了$(handler) 其他的ready方法都被棄用。

官方聲明為此:

這是因為選擇器并沒有和ready()建立聯系,不僅低效而且會導致瀏覽器引擎對該方法的行為進行不正確的假設。

ready 事件和 load 事件的區別

當DOM加載完畢且元素能夠被安全訪問時就會觸發ready事件。另一方面,load事件卻在DOM和所有資源加載后觸發。

可以像下面這樣使用load事件:

$(window).on("load", function(){ // Handler when all assets (including images) are loaded});

這樣的話,不僅僅要等到DOM結構能完全訪問,而且還需要等到所有的圖片資源完全加載完畢(加載時間取決于圖片文件大小)才能執行函數。

正常的DOM操作你可能不需要load事件,但是如果你想要在所有的資源被加載完畢之前展示一個旋轉的加載器樣式,比如,又或者你想要用JS計算一下圖片的大小,這可能是一個好的選擇。

你可能不需要jQuery.ready()

ready 方法可以確保代碼只在所有DOM元素能被安全操縱時才執行。 但這意味著什么呢?這意味著當你要執行的js代碼嵌在HTML中某個片段中時,瀏覽器也要加載完以下元素才能執行。

就像下面這個例子一樣:

<!doctype html><html> <head> <meta charset="utf-8"> <title>.ready() tutorial</title> <script src="https://cdn.jsdelivr.net/jquery/latest/jquery.min.js"></script> <script>  $(function(){ // .ready() callback, is only executed when the DOM is fully loaded  var length = $("p").length;  // The following will log 1 to the console, as the paragraph exists.  // This is the evidence that this method is only called when the  // DOM is fully loaded  console.log(length);  }); </script> </head> <body> <p>I'm the content of this website</p> </body></html>

如果你要執行的javascript代碼放在body末尾,你就可能不需要使用ready()方法,因為瀏覽器解析到javascript時你可能試圖操縱和訪問的DOM元素已經被加載完了:

<!doctype html><html> <head> <meta charset="utf-8"> <title>.ready() tutorial</title> </head> <body> <p>I'm the content of this website</p> <script src="https://cdn.jsdelivr.net/jquery/latest/jquery.min.js"></script> <script>  var length = $("p").length;  // The following will log 1 to the console, as the paragraph exists.  console.log(length); </script> </body></html>

原生JavaScript ready()替代

對于現代瀏覽器以及IE9+,你可以通過監聽 DOMContentLoaded 事件實現ready()相同的功能:

document.addEventListener("DOMContentLoaded", function(){ // Handler when the DOM is fully loaded});

但是,請注意,如果事件已經發射,回調將不會被執行。為了確保回調總是運行,jQuery檢查文檔reference)的“readyState”屬性,如果屬性值變為 complete,則立即執行回調函數:

var callback = function(){ // Handler when the DOM is fully loaded};if ( document.readyState === "complete" || (document.readyState !== "loading" && !document.documentElement.doScroll)) { callback();} else { document.addEventListener("DOMContentLoaded", callback);}

包括domReady庫,已經實現了這個解決方案。

老版本的IE瀏覽器

對于IE8及以下的瀏覽器,你能使用onreadystatechange 事件去監聽文檔的readyState 屬性:

document.attachEvent("onreadystatechange", function(){ // check if the DOM is fully loaded if(document.readyState === "complete"){ // remove the listener, to make sure it isn't fired in future document.detachEvent("onreadystatechange", arguments.callee); // The actual handler... }});

或者你可以使用Load事件,如jQuery,這樣可以在任何瀏覽器上運行。這也會導致一個時間延遲,因為它會等待所有的資產被加載。

注意,在這個解決方案中你也要檢查readyState,如上文所述,這樣能確?;卣{總是能夠被執行。

總結

以上就是這篇文章的全部內容了,如果你正在尋找一種原生js替代ready方法,你可以結合DOMContentLoaded事件一起處理。如果你的系統需要兼容IE話,你要確保DOM加載完成。希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
韩日精品中文字幕| 国产成人短视频| 日韩欧美亚洲一二三区| 日韩欧美一区二区三区| 国产精品一区二区三区在线播放| 日韩免费av片在线观看| 久久的精品视频| 日日噜噜噜夜夜爽亚洲精品| 国产精品入口免费视频一| 一区二区三区回区在观看免费视频| 91福利视频在线观看| 成人中心免费视频| 国产91对白在线播放| 精品偷拍各种wc美女嘘嘘| 久久久亚洲欧洲日产国码aⅴ| 亚洲第一综合天堂另类专| 久久久久久久一区二区三区| 91精品国产精品| 欧美日韩激情视频| 成人免费网站在线看| 欧美在线观看网站| 久久av红桃一区二区小说| 在线视频日本亚洲性| 久久精品视频网站| 一区二区福利视频| 国产精品自在线| 2019亚洲日韩新视频| 久久99久久亚洲国产| 97精品在线观看| 久久九九热免费视频| 97国产精品久久| 日韩中文字幕免费看| 亚洲成**性毛茸茸| 国产成人综合av| 亚洲精品国产拍免费91在线| 91亚洲va在线va天堂va国| 日韩经典中文字幕在线观看| 丰满岳妇乱一区二区三区| 午夜精品福利在线观看| 成人淫片在线看| 久久激情视频久久| 久久综合五月天| 97香蕉超级碰碰久久免费软件| 成人黄色中文字幕| 国产精品视频白浆免费视频| 97久久精品人人澡人人爽缅北| 日韩在线www| 欧美成人午夜影院| 久久精品99国产精品酒店日本| 国产精品稀缺呦系列在线| 亚洲网站视频福利| 欧美高清在线播放| 欧美另类交人妖| 国产精品女主播| 免费91麻豆精品国产自产在线观看| 国产日韩欧美自拍| 国产一区二区成人| 亚洲国产精品网站| 亚洲精品久久久久久久久久久| 成人黄色免费在线观看| 亚洲剧情一区二区| 欧美在线视频在线播放完整版免费观看| 日韩欧美高清在线视频| 91色精品视频在线| 欧美区二区三区| 青青草原成人在线视频| 亚洲国产精品久久91精品| 久久色在线播放| 亚洲级视频在线观看免费1级| 亚洲乱码一区二区| 国产成人av在线播放| 成人午夜激情免费视频| 亚洲国产欧美日韩精品| 成人网址在线观看| 亚洲91精品在线| 欧美人在线观看| 欧美成人激情在线| 亚洲色图av在线| 国产美女精品视频免费观看| 成人精品视频99在线观看免费| 国产精品一区二区av影院萌芽| 精品无码久久久久久国产| 青草青草久热精品视频在线网站| 高清欧美性猛交xxxx| 青青草原成人在线视频| 91精品国产免费久久久久久| 久久精品国亚洲| 91久久精品久久国产性色也91| 国产中文日韩欧美| 日韩欧美在线第一页| 国产精品电影在线观看| 久久综合伊人77777尤物| 国产精品久久久av久久久| 国产精品视频在线观看| 久久久久久久国产| 日本精品久久电影| 久久久久中文字幕2018| 4388成人网| 91在线观看免费高清完整版在线观看| 亚洲第一天堂无码专区| 久久在精品线影院精品国产| 国产精品久久久久aaaa九色| 在线视频欧美日韩精品| 精品少妇一区二区30p| 97在线视频免费看| 久久久久久高潮国产精品视| 亚洲xxxx18| 国产视频久久网| 免费91在线视频| 法国裸体一区二区| 亚洲专区中文字幕| 亚洲国模精品一区| 高清欧美电影在线| 久久久精品视频在线观看| 久久精品国产欧美激情| www.久久草.com| 欧美片一区二区三区| 久久免费成人精品视频| 成人免费淫片aa视频免费| 日韩av成人在线观看| 欧美国产日产韩国视频| 久久伊人精品一区二区三区| 久久精品国产清自在天天线| 午夜精品国产精品大乳美女| 国模极品一区二区三区| 欧美成人一区二区三区电影| 精品欧美国产一区二区三区| 国产精品久久久久久久久免费看| 91在线中文字幕| 午夜精品一区二区三区视频免费看| 国产日韩一区在线| 亚洲欧美在线一区| 一区二区三区在线播放欧美| 日韩中文字幕在线看| 日韩免费精品视频| 国产精品久久久久久久午夜| 免费91麻豆精品国产自产在线观看| 色偷偷av亚洲男人的天堂| 亚洲а∨天堂久久精品9966| 久久高清视频免费| 97在线精品国自产拍中文| 97国产在线观看| 热re91久久精品国99热蜜臀| 国产精品久久久久久久久久免费| 黄色成人在线播放| www欧美xxxx| 久久久精品在线观看| 日韩av在线最新| 日韩精品极品在线观看播放免费视频| 久久深夜福利免费观看| 91香蕉嫩草影院入口| 日韩中文字幕免费看| 国产欧美一区二区| 日韩在线免费视频| 亚洲精品自在久久| 欧美中文字幕在线播放| 日韩中文字幕不卡视频| 欧美精品在线第一页| 欧美夫妻性生活视频| 91久久精品国产91久久| 亚洲电影免费观看高清完整版| 51视频国产精品一区二区| www.美女亚洲精品| 日韩电影免费在线观看中文字幕|