国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

Query中click(),bind(),live(),delegate()的區別

2024-05-06 15:55:28
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了Query中click(),bind(),live(),delegate()之間的區別。需要的朋友可以過來參考下,希望對大家有所幫助

click(),bind(),live()都是執行事件時使用的方法,他們之前是有一些區別的,我們在使用這些方法時應該根據需要進行選擇。

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

復制代碼 代碼如下:


$("a").click(function(){
   alert("hello");
});


當點擊<a>時,輸出hello。

2.click()方法是bind()方法的一種簡單方法。在bind()中,jQuery所有JavaScript事件對象,比如focus, mouseover, 和 resize,都是可以作為type參數傳遞進來的。我們直接看看jQuery文檔中的一個例子:

復制代碼 代碼如下:


var message = "left";
$("a").bind("click", function() {
   alert(message);
   return false;
});var message = "right";
$("a").bind("contextmenu", function() {
   alert(message);
   return false;
});


上邊代碼中,無論是左鍵單擊還是右鍵單擊<a>輸出總是"right"。為了解決這個問題,我們可以將message作為data參數傳遞到到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;
});


這樣當我們左鍵單擊<a>時,輸出"left";當右鍵單擊<a>時,輸出"right"。

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

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

復制代碼 代碼如下:


$("div.live").bind("click", function() {
   alert("success");
});


此時,當點擊class為live的div時,輸出"success"。此時如果有一個新的元素添加了進來,如下:

復制代碼 代碼如下:


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


這時,當使用上邊方法點擊class為live的a標簽時,不會執行。原因在于,這個元素是在調用bind()之后添加的,而使用live()方法使得在后邊添加的元素也能夠執行相應的事件,如下:

復制代碼 代碼如下:


$("div.live").live("click", function() {
   alert("success");
});


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

最后,看看delegate()方法,這個方法到目前為止我自己還沒有使用過,應該是在1.4.2中才有的。
live()方法的一個不足在于它不支持鏈式寫法:

復制代碼 代碼如下:


$("#test").children("a").live("mouseover", function() {
    alert("hello");
});


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

復制代碼 代碼如下:


$("#test").delegate("a", "mouseover", function() {
    alert("hello");
});


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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 衡东县| 南汇区| 丰台区| 河池市| 罗甸县| 鹤峰县| 湖南省| 吴桥县| 依安县| 皮山县| 韩城市| 资中县| 西安市| 吉水县| 微山县| 临漳县| 沙河市| 左贡县| 大方县| 彰化县| 临清市| 黑山县| 潼关县| 兴和县| 吉首市| 宽城| 绥滨县| 抚顺市| 娄底市| 襄城县| 扎囊县| 仁怀市| 布尔津县| 石狮市| 乳山市| 印江| 塔河县| 宜宾市| 新闻| 凤山县| 克拉玛依市|