首先介紹這兩個方法之前,我們常用的是click()方法
。 代碼如下:
$("a").click(function() {
alert("hello");
});
click()方法是bind()方法的一種簡單方法。在bind()中,
jQuery所有JavaScript事件對象,比如focus, mouseover,和resize,
都是可以作為type參數傳遞進來的。
參數:type,[data],function(eventObject)
例如:
。 代碼如下:
$("p").bind("click",function(){
alert("hello");
})
也可以傳參
。 代碼如下:
var message = "how are you!";
$("p").bind("click",{msg:message},function(e){
alert(e.data.msg);
})
live()給所有匹配的元素附加一個事件處理函數,
即使這個元素是以後再添加進來的也有效。如下:
。 代碼如下:
<tr class="mytr">
<td class="mytd">Click me</td>
</tr>
$(".mytd").bind("click",function(){
alert("hello");
})
點擊Clike me 會彈出hello
此時添加一個新的元素進來
。 代碼如下:
$(".mytr").after("<tr><td class='mytd'>後加的</td></tr>");
這時 再使用bind點擊"後加的"不會執行
改為使用live()方法
。 代碼如下:
$(".mytd").live("click",function(){
alert("hello");
})
.live()方法能對一個還沒有添加進DOM的元素有效,是由於使用了事件委托:
綁定在祖先元素上的事件處理函數可以對在後代上觸發的事件作出回應。
傳遞給 .live() 的事件處理函數不會綁定在元素上,而是把他作為一個特殊的事件處理函數,綁定在 DOM 樹的根節點上。