最近工作中需要實現一個動態加載的功能,需要使用到jQuery的live方法來給后續新增的元素綁定事件。在學習和實踐的過程中,深入了解了jQuery 3.1版本中live方法的具體用法及優劣勢。
live方法在jQuery 1.7版本中被廢棄,轉而推薦使用on方法。但在jQuery 3.0版本中,live方法又被重新引入,而且還做出了一些改進,可以用于綁定事件處理程序,而且性能也得到了提高。
$(selector).live(events, data, handler); //老版本的寫法 $(document).on(events, selector, data, handler); //新版本的寫法
在jQuery 3.1中,live方法通過on進行了封裝,相比于之前的版本,性能有了很大提升。同時,也更加精確的指定了事件源和事件類型。
當然,live方法也有一些限制。例如它僅僅局限于mousemove,mousedown,mouseup,keydown,keyup,scroll,resize和click等一些DOM事件。還有,它必須綁定在document對象上,而不是像on方法一樣可以綁定在任意的元素上。
$(document).on("click",".btn",function(){ // click事件的回調函數 });
在實際的使用中,我們可以結合delegate方法來實現類似的效果。delegate的作用是將事件綁定到一個父元素上,然后通過一個子選擇器來選擇準確的元素,實現事件委托。
$( "table tbody" ).delegate( "td", "click", function() { // click事件的回調函數 });
總的來說,雖然live方法在jQuery 3.1中已被重新引入,但在實際使用中需要慎重考慮。我們可以結合其他的綁定方法,來根據實際需求選擇最合適的方法。