Query中click(),bind(),live(),delegate()的區(qū)別
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)綄懛ǎ?BR>
$("#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í)有所幫助。
- jQuery事件綁定.on()簡(jiǎn)要概述及應(yīng)用
- jquery移除、綁定、觸發(fā)元素事件使用示例詳解
- jQuery中的.bind()、.live()和.delegate()之間區(qū)別分析
- JQuery中綁定事件(bind())和移除事件(unbind())
- JQuery中Bind()事件用法分析
- jQuery事件綁定on()、bind()與delegate() 方法詳解
- 讓IE8瀏覽器支持function.bind()方法
- 淺談javascript中call()、apply()、bind()的用法
- jQuery綁定事件方法及區(qū)別(bind,click,on,live,one)
相關(guān)文章
jquery實(shí)現(xiàn)表格中點(diǎn)擊相應(yīng)行變色功能效果【實(shí)例代碼】
下面小編就為大家?guī)?lái)一篇jquery實(shí)現(xiàn)表格中點(diǎn)擊相應(yīng)行變色功能效果【實(shí)例代碼】。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考2016-05-05jquery ztree實(shí)現(xiàn)樹(shù)的搜索功能
這篇文章主要為大家詳細(xì)介紹了jquery ztree實(shí)現(xiàn)樹(shù)的搜索功能,zTree是利用 JQuery 的核心代碼,實(shí)現(xiàn)一套能完成大部分常用功能的Tree插件,對(duì)ztree感興趣的小伙伴們可以參考一下2016-02-02基于jQuery的遍歷同id元素 并響應(yīng)事件的代碼
寫網(wǎng)頁(yè)的時(shí)候,腳本循環(huán)的時(shí)候有很多時(shí)候都會(huì)循環(huán)出來(lái)同id的網(wǎng)頁(yè)元素,下面貼出來(lái)代碼,如何利用jQuery對(duì)這些元素進(jìn)行逐一遍歷并可響應(yīng)消息2012-06-06jquery實(shí)現(xiàn)帶二級(jí)菜單的導(dǎo)航示例
這篇文章主要介紹了jquery實(shí)現(xiàn)帶二級(jí)菜單的導(dǎo)航示例,需要的朋友可以參考下2014-04-04jQuery 綁定事件到動(dòng)態(tài)創(chuàng)建的元素上的方法實(shí)例
這篇文章介紹了jQuery 綁定事件到動(dòng)態(tài)創(chuàng)建的元素上的方法實(shí)例,有需要的朋友可以參考一下2013-08-08jQuery模擬下拉框選擇對(duì)應(yīng)菜單的內(nèi)容
這篇文章主要介紹了jQuery模擬下拉框選擇對(duì)應(yīng)菜單的內(nèi)容,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-03-03jquery.blockUI.js上傳滾動(dòng)等待效果實(shí)現(xiàn)思路及代碼
上傳滾動(dòng)等待效果想必大家在很多場(chǎng)合都有見(jiàn)過(guò)吧,本文將介紹jquery.blockUI.js實(shí)現(xiàn)上傳滾動(dòng)等待效果,感興趣的你可不要錯(cuò)過(guò)了哈,希望可以幫助到你2013-03-03使用jQuery的ajax功能實(shí)現(xiàn)的RSS Reader 代碼
Rss閱讀器挺不錯(cuò)的。我覺(jué)得如果在igoogle或是dropthings這種形式的portal下來(lái)放很多RSS模塊顯示自己每天需要關(guān)注的信息那將會(huì)減少大家很多的打開(kāi)瀏覽器和輸入網(wǎng)址的時(shí)間。2009-09-09