jQuery的Read()方法代替原生JS詳解
在jQuery 3.0的版本前, ready經典用法是用一個匿名函數,像這樣:
$(document).ready(function() {
// Handler for .ready() called.
});
jQuery 3.0 ready() 變化
在jQuery 3.0發(fā)布之前,有以下幾種方法稱之為ready方法:
在document元素上操作: $(document).ready(handler);
在空元素上操作: $().ready(handler);
或者直接(即不在一個具體的元素上)操作: $(handler);
上述所有命名的變種在功能上是等價的。無論是哪個元素,在DOM加載完畢之后其指定的處理程序都將會被調用。換句話說,這里的DOM加載完畢并不表示在文檔中的某個具體的元素,比如img元素,加載完畢。相反,這里表示的是整個DOM樹加載完畢。
在jQuery 3.0中,除了$(handler) 其他的ready方法都被棄用。
官方聲明為此:
這是因為選擇器并沒有和ready()建立聯系,不僅低效而且會導致瀏覽器引擎對該方法的行為進行不正確的假設。
ready 事件和 load 事件的區(qū)別
當DOM加載完畢且元素能夠被安全訪問時就會觸發(fā)ready事件。另一方面,load事件卻在DOM和所有資源加載后觸發(fā)。
可以像下面這樣使用load事件:
$(window).on("load", function(){
// Handler when all assets (including images) are loaded
});
這樣的話,不僅僅要等到DOM結構能完全訪問,而且還需要等到所有的圖片資源完全加載完畢(加載時間取決于圖片文件大?。┎拍軋?zhí)行函數。
正常的DOM操作你可能不需要load事件,但是如果你想要在所有的資源被加載完畢之前展示一個旋轉的加載器樣式,比如,又或者你想要用JS計算一下圖片的大小,這可能是一個好的選擇。
你可能不需要jQuery.ready()
ready 方法可以確保代碼只在所有DOM元素能被安全操縱時才執(zhí)行。 但這意味著什么呢?這意味著當你要執(zhí)行的js代碼嵌在HTML中某個片段中時,瀏覽器也要加載完以下元素才能執(zhí)行。
就像下面這個例子一樣:
<!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>
如果你要執(zhí)行的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+,你可以通過監(jiān)聽 DOMContentLoaded 事件實現ready()相同的功能:
document.addEventListener("DOMContentLoaded", function(){
// Handler when the DOM is fully loaded
});
但是,請注意,如果事件已經發(fā)射,回調將不會被執(zhí)行。為了確保回調總是運行,jQuery檢查文檔reference)的“readyState”屬性,如果屬性值變?yōu)?complete,則立即執(zhí)行回調函數:
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 事件去監(jiān)聽文檔的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,如上文所述,這樣能確保回調總是能夠被執(zhí)行。
總結
以上就是這篇文章的全部內容了,如果你正在尋找一種原生js替代ready方法,你可以結合DOMContentLoaded事件一起處理。如果你的系統(tǒng)需要兼容IE話,你要確保DOM加載完成。希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。
- nodejs的HTML分析利器node-jquery用法淺析
- Jquery通過ajax請求NodeJS返回json數據實例
- 原生JS版和jquery版實現checkbox的全選/全不選/點選/行內點選(Mr.Think)
- jQuery.datatables.js插件用法及api實例詳解
- jQuery+json實現動態(tài)創(chuàng)建復雜表格table的方法
- jquery popupDialog 使用 加載jsp頁面的方法
- 分享javascript、jquery實用代碼段
- jquery中用jsonp實現搜索框功能
- 使用jquery.qrcode.js生成二維碼插件
- jQuery與JavaScript節(jié)點創(chuàng)建方法的對比
相關文章
輕松掌握jQuery中wrap()與unwrap()函數的用法
wrap()能夠將指定HTML元素包裹DOM結構,與之相反unwrap()函數則是將DOM去掉^^下面讓我們來以兩個小例子輕松掌握jQuery中wrap()與unwrap()函數的用法:)2016-05-05
jQuery獲取select選中的option的value值實現方法
下面小編就為大家?guī)硪黄猨Query獲取select選中的option的value值實現方法。小編覺得挺不錯的,現在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-08-08
jQuery的實現原理的模擬代碼 -4 重要的擴展函數 extend
在上兩篇文章中,我們看到每次要通過 jQuery 的原型增加共享方法的時候,都需要通過 jQuery.fn 一個個進行擴展,非常麻煩.2010-08-08

