一区二区三区日韩精品-日韩经典一区二区三区-五月激情综合丁香婷婷-欧美精品中文字幕专区

分享

jQuery方法區(qū)別:click() bind() live() delegate()區(qū)別

 Java收藏資料 2016-06-06

click(),bind(),live()都是執(zhí)行事件時(shí)使用的方法,他們之前是有一些區(qū)別的,我們?cè)谑褂眠@些方法時(shí)應(yīng)該根據(jù)需要進(jìn)行選擇。

1.click()方法是我們經(jīng)常使用的單擊事件方法:

$("a").click(function() {

   alert("hello");

});

當(dāng)點(diǎn)擊<a>時(shí),輸出hello。

2.click()方法是bind()方法的一種簡(jiǎn)單方法。

在bind()中,jQuery所有JavaScript事件對(duì)象,比如focus, mouseover, 和 resize,都是可以作為type參數(shù)傳遞進(jìn)來(lái)的。我們直接看看jQuery文檔中的一個(gè)例子:

var message = "left";

$("a").bind("click", function() {

   alert(message);

   return false;

});

 

var message = "right";

$("a").bind("contextmenu", function() {

   alert(message);

   return false;

});

上邊代碼中,無(wú)論是左鍵單擊還是右鍵單擊<a>輸出總是"right"。為了解決這個(gè)問(wèn)題,我們可以將message作為data參數(shù)傳遞到到bind()方法中,如下:

var message = "left";

$("a").bind("click", { msg: message }, function(e) {

   alert(e.data.msg);

   return false;

});

 

var message = "right";

$("a").bind("contextmenu", { msg: message }, function(e) {

   alert(e.data.msg);

   return false;

});

這樣當(dāng)我們左鍵單擊<a>時(shí),輸出"left";當(dāng)右鍵單擊<a>時(shí),輸出"right"。

可見(jiàn),一般情況下我們使用click()方法就可以了,當(dāng)需要處理上邊這種情況時(shí),我們要使用bind()方法。

3.live()給所有匹配的元素附加一個(gè)事件處理函數(shù),即使這個(gè)元素是以后再添加進(jìn)來(lái)的也有效。如下:

$("div.live").bind("click", function() {

   alert("success");

});

此時(shí),當(dāng)點(diǎn)擊class為live的div時(shí),輸出"success"。此時(shí)如果有一個(gè)新的元素添加了進(jìn)來(lái),如下:

$("<div class="live" href="#">live</div>").appendTo("body");

這時(shí),當(dāng)使用上邊方法點(diǎn)擊class為live的a標(biāo)簽時(shí),不會(huì)執(zhí)行。原因在于,這個(gè)元素是在調(diào)用bind()之后添加的,而使用live()方法使得在后邊添加的元素也能夠執(zhí)行相應(yīng)的事件,如下:

$("div.live").live("click", function() {

   alert("success");

});

這樣,當(dāng)我們單擊class為live的a標(biāo)簽時(shí),如果此a標(biāo)簽是后邊添加的,也能照常輸出"success"。至于原因,在這里不做具體的說(shuō)明,本篇主要比較幾種方法的區(qū)別。

最后,看看delegate()方法,這個(gè)方法到目前為止我自己還沒(méi)有使用過(guò),應(yīng)該是在1.4.2中才有的。

live()方法的一個(gè)不足在于它不支持鏈?zhǔn)綄懛ǎ?/p>

$("#test").children("a").live("mouseover", function() {

    alert("hello");

});

上邊這種寫法并不會(huì)輸出,我們使用delegate()可以寫為:

$("#test").delegate("a", "mouseover", function() {

    alert("hello");

});

這樣就可以正常的輸出我們想要的結(jié)果了。本篇總結(jié)了click()、bind()、live()和delegate()方法,其中并沒(méi)有做非常詳細(xì)的解釋,僅望能對(duì)大家在具體使用時(shí)有所幫助。

    本站是提供個(gè)人知識(shí)管理的網(wǎng)絡(luò)存儲(chǔ)空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn)。請(qǐng)注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購(gòu)買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊一鍵舉報(bào)。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評(píng)論

    發(fā)表

    請(qǐng)遵守用戶 評(píng)論公約

    類似文章 更多

    内射精子视频欧美一区二区| 黄色国产自拍在线观看| 国产精品大秀视频日韩精品| 欧美日韩国产综合特黄| 91亚洲国产成人久久| 有坂深雪中文字幕亚洲中文| 国产视频福利一区二区| 国产黄色高清内射熟女视频| 在线观看国产午夜福利| 国产精品色热综合在线| 尤物久久91欧美人禽亚洲| 国产精品日韩欧美第一页| 蜜臀人妻一区二区三区| 夜夜嗨激情五月天精品| 亚洲日本韩国一区二区三区| 国产精品推荐在线一区| 91香蕉视频精品在线看| 欧美三级不卡在线观线看| 成年男女午夜久久久精品| 国产精品香蕉在线的人| 亚洲精品国产美女久久久99| 高潮少妇高潮久久精品99| 一区二区三区四区亚洲另类 | 精品久久久一区二区三| 亚洲第一香蕉视频在线| 日本少妇中文字幕不卡视频| 99久久精品免费看国产高清| 欧美日韩国产亚洲三级理论片| 国产免费一区二区三区av大片| 免费精品国产日韩热久久| 成人午夜免费观看视频| 熟女乱一区二区三区丝袜| 天堂网中文字幕在线观看| 亚洲色图欧美另类人妻| 少妇熟女亚洲色图av天堂| 欧美在线视频一区观看| 国产精品免费福利在线| 色婷婷国产熟妇人妻露脸| 亚洲精品福利视频在线观看| 人妻少妇系列中文字幕| 日本少妇aa特黄大片|