jQuery live與bind的區別在哪裡

平時在使用jQuery進行AJAX操作的時候,新生成的元素事件會失效,有時候不得不重新綁定一下事件,但是這樣做很麻煩。例如評論分頁後對評論內容的JS驗證會失效等。在jQuery1.3之前有一個插件會解決這個問題http://plugins.jquery.com/project/livequery ,jQuery1.3以及之後的版本中增加了一個live()方法,下面是手冊上的說明:

jQuery live與bind的區別在哪裡

jQuery 1.3及之後版本中新增的方法。給所有當前以及將來會匹配的元素綁定一個事件處理函數(比如click事件)。也能綁定自定義事件。

目前支持 click, dblclick, mousedown, mouseup, mousemove, mouseover, mouseout, keydown, keypress, keyup。

還不支持 blur, focus, mouseenter, mouseleave, change, submit

jQuery live與bind的區別在哪裡

與bind()不同的是,live()一次只能綁定一個事件。

這個方法跟傳統的bind很像,區別在於用live來綁定事件會給所有當前以及將來在頁面上的元素綁定事件(使用委派的方式)。比如說,如果你給頁 面上所有的li用live綁定了click事件。那麼當在以後增加一個li到這個頁面時,對於這個新增加的li,其click事件依然可用。而無需重新給 這種新增加的元素綁定事件。

jQuery live與bind的區別在哪裡

.live()與流行的liveQuery插件很像,但有以下幾個主要區別:

.live 目前只支持所有事件的子集,支持列表參考上面的說明。

.live 不支持liveQuery提供的“無事件”樣式的回調函數。.live只能綁定事件處理函數。

.live 沒有”setup”和”cleanup”的過程。因為所有的事件是委派而不是直接綁定在元素上的。

要移除用live綁定的事件,請用die方法

jQuery live與bind的區別在哪裡

用法示例:

jquery:

$(“.myDiv”).live(“click”, function(){

alert(“clicked!”);

});

如果使用javascript動態創建一個class為mydiv的元素,點擊元素依然會有彈出。為什麼使用live後就有了呢?這是因為 jquery利用了事件的冒泡機制,直接把事件綁定在了document上,然後通過event.target找出事件的來源。這跟 jquery.livequery插件不一樣,jquery.livequery每20毫秒做一次檢查,如有新生成則重新綁定一次事件。

jQuery live與bind的區別在哪裡

使用live當然有利也有弊:

好處就是:元素更新時不用反覆去定義事件。

壞處就是:把事件綁定在document上會在頁面上每一個元素都呼叫一次,如使用不當會嚴重影響性能。而且不支持blur, focus, mouseenter, mouseleave, change, submit。


分享到:


相關文章: