這篇文章主要介紹了jQuery對(duì)象的鏈?zhǔn)讲僮饔梅?結(jié)合實(shí)例形式分析了鏈?zhǔn)讲僮鞯脑?、特點(diǎn)及相關(guān)注意事項(xiàng),具有一定參考借鑒價(jià)值,需要的朋友可以參考下
本文實(shí)例講述了jQuery對(duì)象的鏈?zhǔn)讲僮饔梅ā7窒斫o大家供大家參考,具體如下:
jQuery對(duì)象的鏈?zhǔn)讲僮?/P>
首先來看一個(gè)例子:
代碼如下:
$("#myphoto").css("border","solid 2px#FF0000").attr("alt"," good");
對(duì)一個(gè)jQuery對(duì)象先調(diào)用了css()函數(shù)修改樣式,然后使用attr()函數(shù)修改屬性,這種調(diào)用方式象鏈一樣,所以稱為"鏈?zhǔn)讲僮?。
鏈?zhǔn)讲僮髂軌蜃尨a變得簡潔,因?yàn)橥梢栽谝粭l語句中實(shí)現(xiàn)以往多條語句才能完成的任務(wù)。比如如果不使用鏈?zhǔn)讲僮鳎枰脙蓷l語句才能完成上面的任務(wù):
$("#myphoto").css("border","solid 2px#FF0000");
$("#myphoto").arrt("alt","good");
除了增加了代碼量,還調(diào)用了兩次選擇器,降低了速度。
在一個(gè)較短的鏈?zhǔn)讲僮髦?,往往語句比較清晰,可以分步驟地對(duì)jQuery對(duì)象實(shí)現(xiàn)各種操作。但是鏈?zhǔn)讲僮鞑粦?yīng)該太長,否則會(huì)造成語句難以理解,因?yàn)橐榭磈Query對(duì)象當(dāng)前的狀態(tài)并不是容易的事,尤其如果涉及jQuery對(duì)象中元素的增刪操作是更加難以判斷。
并不是所有的jQuery函數(shù)都可以使用鏈?zhǔn)讲僮?。這與鏈?zhǔn)讲僮鞯脑碛嘘P(guān),之所以可以實(shí)現(xiàn)鏈?zhǔn)讲僮魇且驗(yàn)槠渲械拿總€(gè)函數(shù)返回的都是jQuery對(duì)象本身。在jQuery類庫的內(nèi)部實(shí)現(xiàn)中,雖然很多的函數(shù)都返回jQuery對(duì)象本身,但都是通過調(diào)用內(nèi)部有限的幾個(gè)函數(shù)實(shí)現(xiàn)的,比如attr()函數(shù)設(shè)置屬性石,實(shí)際上最后調(diào)用了"jQuery.each(object,callback,args)"方法。注意此方法不是jQuery對(duì)象方法,jQuery對(duì)象方法也有一個(gè)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對(duì)象,即jQuery對(duì)象。最后返回的還是jQuery對(duì)象。
可以使用下面的原則判斷一個(gè)函數(shù)返回的時(shí)候是jQuery對(duì)象,即是否可以用于鏈?zhǔn)讲僮鳌?/P>
除了獲取某些數(shù)據(jù)的函數(shù),比如獲取屬性值"attr(name)",獲取集合大小"size()"這些函數(shù)明顯是返回?cái)?shù)據(jù)的。除了這些函數(shù)之外的jQuery函數(shù)都可以用于鏈?zhǔn)讲僮鳎热缭O(shè)置屬性"attr(name.value)"。
"$"變量的使用
"$"變量是"jQuery"變量的引用。"jQuery"變量是全局變量,jQuery對(duì)象是指"jQUery.fn",不要混淆。"jQuery"變量類似于靜態(tài)類,上面的方法都是靜態(tài)方法,可以在任何時(shí)刻調(diào)用。比如"jQuery.each"。"jQuery.fn"是實(shí)例方法,只能在jQuery對(duì)象上調(diào)用。比如"jQuery.fn.each()"方法只能通過"$('#id').each"這種形式調(diào)用。
前面提到,可以使用"$"代替"jQuery",因?yàn)樵趈Query的內(nèi)部有如下實(shí)現(xiàn):
jQuery=window.jQuery=window.$
所以"$"變量和"jQuery"變量實(shí)際上是Window對(duì)象的屬性,也就是全局變量??梢栽陧撁嫔系萌魏蔚胤秸{(diào)用。
希望本文所述對(duì)大家jquery程序設(shè)計(jì)有所幫助。