摘自 jQuery 1.4.1 中文參考:
事件委托
.live() 方法能對一個還沒有添加進DOM的元素有效,是由於使用了事件委托:綁定在祖先元素上的事件處理函數可以對在後代上觸發的事件作出回應。傳遞給 .live() 的事件處理函數不會綁定在元素上,而是把他作為一個特殊的事件處理函數,綁定在 DOM 樹的根節點上。在我們的例子中,當點擊新的元素後,會依次發生下列步驟:
- 生成一個click事件傳遞給 <div> 來處理
- 由於沒有事件處理函數直接綁定在 <div> 上,所以事件冒泡到DOM樹上
- 事件不斷冒泡一直到DOM樹的根節點,默認情況下上面綁定了這個特殊的事件處理函數。
- 執行由 .live() 綁定的特殊的 click 事件處理函數。
- 這個事件處理函數首先檢測事件對象的 target 來確定是不是需要繼續。這個測試是通過檢測 $(event.target).closest('.clickme') 能否找到匹配的元素來實現的。
- 如果找到了匹配的元素,那麼調用原始的事件處理函數。
由於只有在事件發生時才會在上面的第五步裡做測試,因此在任何時候添加的元素都能夠響應這個事件