jQuery對象的鏈式操作用法分析
來源:易賢網 閱讀:1073 次 日期:2016-07-01 15:34:46
溫馨提示:易賢網小編為您整理了“jQuery對象的鏈式操作用法分析”,方便廣大網友查閱!

這篇文章主要介紹了jQuery對象的鏈式操作用法,結合實例形式分析了鏈式操作的原理、特點及相關注意事項,具有一定參考借鑒價值,需要的朋友可以參考下

本文實例講述了jQuery對象的鏈式操作用法。分享給大家供大家參考,具體如下:

jQuery對象的鏈式操作

首先來看一個例子:

代碼如下:

$("#myphoto").css("border","solid 2px#FF0000").attr("alt"," good");

對一個jQuery對象先調用了css()函數修改樣式,然后使用attr()函數修改屬性,這種調用方式象鏈一樣,所以稱為"鏈式操作"。

鏈式操作能夠讓代碼變得簡潔,因為往往可以在一條語句中實現以往多條語句才能完成的任務。比如如果不使用鏈式操作,需要用兩條語句才能完成上面的任務:

$("#myphoto").css("border","solid 2px#FF0000");

$("#myphoto").arrt("alt","good");

除了增加了代碼量,還調用了兩次選擇器,降低了速度。

在一個較短的鏈式操作中,往往語句比較清晰,可以分步驟地對jQuery對象實現各種操作。但是鏈式操作不應該太長,否則會造成語句難以理解,因為要查看jQuery對象當前的狀態(tài)并不是容易的事,尤其如果涉及jQuery對象中元素的增刪操作是更加難以判斷。

并不是所有的jQuery函數都可以使用鏈式操作。這與鏈式操作的原理有關,之所以可以實現鏈式操作是因為其中的每個函數返回的都是jQuery對象本身。在jQuery類庫的內部實現中,雖然很多的函數都返回jQuery對象本身,但都是通過調用內部有限的幾個函數實現的,比如attr()函數設置屬性石,實際上最后調用了"jQuery.each(object,callback,args)"方法。注意此方法不是jQuery對象方法,jQuery對象方法也有一個each()函數,為"jQuery.fn.each(callback,args)",此函數最后同樣調用jQuery.each函數:

Each:function(callback,args){

  ReturnjQuery.each(this,callback,args);

}

下面看一看jQuery.each函數的返回結果:

Each.function(object,callback,args){

  Retumobject;

}

Object是jQuery.fn對象,即jQuery對象。最后返回的還是jQuery對象。

可以使用下面的原則判斷一個函數返回的時候是jQuery對象,即是否可以用于鏈式操作。

除了獲取某些數據的函數,比如獲取屬性值"attr(name)",獲取集合大小"size()"這些函數明顯是返回數據的。除了這些函數之外的jQuery函數都可以用于鏈式操作,比如設置屬性"attr(name.value)"。

"$"變量的使用

"$"變量是"jQuery"變量的引用。"jQuery"變量是全局變量,jQuery對象是指"jQUery.fn",不要混淆。"jQuery"變量類似于靜態(tài)類,上面的方法都是靜態(tài)方法,可以在任何時刻調用。比如"jQuery.each"。"jQuery.fn"是實例方法,只能在jQuery對象上調用。比如"jQuery.fn.each()"方法只能通過"$('#id').each"這種形式調用。

前面提到,可以使用"$"代替"jQuery",因為在jQuery的內部有如下實現:

jQuery=window.jQuery=window.$

所以"$"變量和"jQuery"變量實際上是Window對象的屬性,也就是全局變量??梢栽陧撁嫔系萌魏蔚胤秸{用。

希望本文所述對大家jquery程序設計有所幫助。

更多信息請查看網絡編程
易賢網手機網站地址:jQuery對象的鏈式操作用法分析

2026上岸·考公考編培訓報班

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關于我們 | 聯(lián)系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權所有:易賢網