這次帶給大家jQuery的Read()方法怎麼取代JS,jQuery的Read()方法取代JS注意事項有哪些,下面就是實戰案例,一起來看一下。
眾所周知在jQuery中ready方法在DOM完全下載後立即執行其中的程式碼。因為它是等待所有的DOM元素都載入完畢,才執行給定的函數,所以你能確定那些試圖操作和存取元素節點的方法都能被執行。而這篇文章要跟大家介紹的是如何用jQuery的Read()方法來取代原生JS,下面來一起看看。
在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,这样可以在任何浏览器上运行。这也会导致一个时间延迟,因为它会等待所有的资产被加载。
相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!
推荐阅读:
以上是jQuery的Read()方法怎麼取代JS的詳細內容。更多資訊請關注PHP中文網其他相關文章!