jQuery對象的鏈式操作用法分析
本文實例講述了jQuery對象的鏈式操作用法。分享給大家供大家參考,具體如下:
jQuery對象的鏈式操作
首先來看一個例子:
對一個jQuery對象先調(diào)用了css()函數(shù)修改樣式,然后使用attr()函數(shù)修改屬性,這種調(diào)用方式象鏈一樣,所以稱為"鏈式操作"。
鏈式操作能夠讓代碼變得簡潔,因為往往可以在一條語句中實現(xiàn)以往多條語句才能完成的任務(wù)。比如如果不使用鏈式操作,需要用兩條語句才能完成上面的任務(wù):
$("#myphoto").css("border","solid 2px#FF0000");
$("#myphoto").arrt("alt","good");
除了增加了代碼量,還調(diào)用了兩次選擇器,降低了速度。
在一個較短的鏈式操作中,往往語句比較清晰,可以分步驟地對jQuery對象實現(xiàn)各種操作。但是鏈式操作不應(yīng)該太長,否則會造成語句難以理解,因為要查看jQuery對象當(dāng)前的狀態(tài)并不是容易的事,尤其如果涉及jQuery對象中元素的增刪操作是更加難以判斷。
并不是所有的jQuery函數(shù)都可以使用鏈式操作。這與鏈式操作的原理有關(guān),之所以可以實現(xiàn)鏈式操作是因為其中的每個函數(shù)返回的都是jQuery對象本身。在jQuery類庫的內(nèi)部實現(xiàn)中,雖然很多的函數(shù)都返回jQuery對象本身,但都是通過調(diào)用內(nèi)部有限的幾個函數(shù)實現(xiàn)的,比如attr()函數(shù)設(shè)置屬性石,實際上最后調(diào)用了"jQuery.each(object,callback,args)"方法。注意此方法不是jQuery對象方法,jQuery對象方法也有一個each()函數(shù),為"jQuery.fn.each(callback,args)",此函數(shù)最后同樣調(diào)用jQuery.each函數(shù):
Each:function(callback,args){
ReturnjQuery.each(this,callback,args);
}
下面看一看jQuery.each函數(shù)的返回結(jié)果:
Each.function(object,callback,args){
Retumobject;
}
Object是jQuery.fn對象,即jQuery對象。最后返回的還是jQuery對象。
可以使用下面的原則判斷一個函數(shù)返回的時候是jQuery對象,即是否可以用于鏈式操作。
除了獲取某些數(shù)據(jù)的函數(shù),比如獲取屬性值"attr(name)",獲取集合大小"size()"這些函數(shù)明顯是返回數(shù)據(jù)的。除了這些函數(shù)之外的jQuery函數(shù)都可以用于鏈式操作,比如設(shè)置屬性"attr(name.value)"。
"$"變量的使用
"$"變量是"jQuery"變量的引用。"jQuery"變量是全局變量,jQuery對象是指"jQUery.fn",不要混淆。"jQuery"變量類似于靜態(tài)類,上面的方法都是靜態(tài)方法,可以在任何時刻調(diào)用。比如"jQuery.each"。"jQuery.fn"是實例方法,只能在jQuery對象上調(diào)用。比如"jQuery.fn.each()"方法只能通過"$('#id').each"這種形式調(diào)用。
前面提到,可以使用"$"代替"jQuery",因為在jQuery的內(nèi)部有如下實現(xiàn):
jQuery=window.jQuery=window.$
所以"$"變量和"jQuery"變量實際上是Window對象的屬性,也就是全局變量??梢栽陧撁嫔系萌魏蔚胤秸{(diào)用。
更多關(guān)于jquery相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《jquery常用操作技巧匯總》、《jQuery常見事件用法與技巧總結(jié)》、《jQuery操作json數(shù)據(jù)技巧匯總》、《jQuery操作xml技巧總結(jié)》及《jQuery擴展技巧總結(jié)》
希望本文所述對大家jquery程序設(shè)計有所幫助。
- jQuery如何將選中的對象轉(zhuǎn)化為原始的DOM對象
- jQuery獲取單擊節(jié)點對象的方法
- jquery遍歷json對象集合詳解
- 解析Jquery中如何把一段html代碼動態(tài)寫入到DIV中(實例說明)
- jQuery實現(xiàn)鼠標跟隨提示層效果代碼(可顯示文本,Div,Table,Html等)
- phpQuery讓php處理html代碼像jQuery一樣方便
- jquery 獲取 outerHtml 包含當(dāng)前節(jié)點本身的代碼
- JQuery獲取與設(shè)置HTML元素的內(nèi)容或文本的實現(xiàn)代碼
- jquery模擬LCD 時鐘的html文件源代碼
- Jquery在指定DIV加載HTML示例代碼
- jquery隨意添加移除html的實現(xiàn)代碼
- jQuery查看選中對象HTML代碼的方法
相關(guān)文章
jQuery模擬html下拉多選框的原生實現(xiàn)方法示例
這篇文章主要介紹了jQuery模擬html下拉多選框的原生實現(xiàn)方法,結(jié)合完整實例形式分析了jQuery動態(tài)操作頁面元素實現(xiàn)select下拉框效果的相關(guān)操作技巧,需要的朋友可以參考下2019-05-05
深入研究jQuery圖片懶加載 lazyload.js使用方法
這篇文章主要介紹了jQuery圖片懶加載 lazyload.js使用方法,通過設(shè)置臨界點,占位符,設(shè)置事件來觸發(fā)加載等等來講解lazyload.js的使用,具體操作步驟大家可查看下文的詳細講解,感興趣的小伙伴們可以參考一下。2017-08-08
了解jQuery技巧來提高你的代碼(個人覺得那個jquery的手冊很不錯)
這個jQuery選擇器實驗室非??幔茉诰€免費使用,當(dāng)然你也能下來到本地離線使用。這個測試頁面包含復(fù)雜的HTML組合字段,然后你能嘗試預(yù)定義使用各種jQuery選擇器。如果這還不夠你也可以自定義選擇器2012-02-02
AspNet中使用JQuery上傳插件Uploadify詳解
Uploadify是JQuery的一個上傳插件,實現(xiàn)的效果非常不錯,帶進度顯示。不過官方提供的實例時php版本的,本文將詳細介紹Uploadify在Aspnet中的使用2015-05-05
jQuery數(shù)據(jù)緩存功能的實現(xiàn)思路及簡單模擬
jQuery緩存系統(tǒng)不僅運用于DOM元素,動畫、事件等都有用到這個緩存系統(tǒng)2013-05-05
基于jquery實現(xiàn)的文字向上跑動類似跑馬燈的效果
這篇文章主要介紹了基于jquery實現(xiàn)的文字向上跑動效果類似跑馬燈,需要的朋友可以參考下2014-06-06

