jQuery實現(xiàn)在新增加的元素上添加事件方法案例分析
本文實例講述了jQuery實現(xiàn)在新增加的元素上添加事件方法。分享給大家供大家參考,具體如下:
最近項目組需要在新增的元素上增加時間,有人說用live方法后來使用的時候發(fā)現(xiàn)jQuery沒有該方法(1.7以上就沒了)替換為on
除了jquery api官方的例子外還有以下的例子可以在新增的元素上添加事件
$(document).on("click",'#lyysb a',function(){
if(!$(this).hasClass('cur')){
$(this).addClass('cur');
} else {
$(this).removeClass('cur');
}
});
但是把事件綁定在docunmet就和原來的live方法沒有區(qū)別了。原先的live()方法,處理函數(shù)是默認綁定在document對象上不能變的,如果DOM嵌套結(jié)構(gòu)很深,事件冒泡通過大量祖先元素會導致較大的性能損失。而使用.on()方法,事件只會綁定到$()函數(shù)的選擇符表達式匹配的元素上,因此可以精確地定位到頁面中的一部分,而事件冒泡的開銷也可以減少。
<div id="zkdiv"> <input type="button" value="展開" id="zk" class="zk"/> <br> </div>
例如我會在zkdiv中動態(tài)添加多個class="zk"的dom節(jié)點,也想對動態(tài)增加的節(jié)點綁定相同的事件則可以通過以下代碼實現(xiàn)
//展開按鈕點擊觸發(fā)事件
$("#zkdiv").on("click",".zk",function(){
console.log("on 點擊一次");
});
var html2 = "<input type='button' class='zk' value='新生成的展開' />";
$("#zkdiv").append(html2);
這樣一來處理函數(shù)就綁定到#zkdiv的選擇器上去了,事件冒泡導致的性能損失會大大降低(使用該方法時要確保.on前面的選擇器能選擇到對象 否則不起作用)
更多關(guān)于jQuery相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《jQuery常見事件用法與技巧總結(jié)》、《jQuery常用插件及用法總結(jié)》、《jQuery操作json數(shù)據(jù)技巧匯總》、《jQuery擴展技巧總結(jié)》、《jQuery拖拽特效與技巧總結(jié)》、《jQuery表格(table)操作技巧匯總》、《jQuery常見經(jīng)典特效匯總》、《jQuery動畫與特效用法總結(jié)》及《jquery選擇器用法總結(jié)》
希望本文所述對大家jQuery程序設計有所幫助。
- jquery移除、綁定、觸發(fā)元素事件使用示例詳解
- jQuery給動態(tài)添加的元素綁定事件的方法
- jQuery動態(tài)添加的元素綁定事件處理函數(shù)代碼
- jQuery 判斷元素上是否綁定了事件
- jQuery中對未來的元素綁定事件用bind、live or on
- jQuery 綁定事件到動態(tài)創(chuàng)建的元素上的方法實例
- jquery動態(tài)添加元素事件失效問題解決方法
- JQuery1.8 判斷元素是否綁定事件的方法
- jquery用data方法獲取某個元素上的事件
- iframe里面的元素觸發(fā)父窗口元素事件的jquery代碼
- JQuery為頁面Dom元素綁定事件及解除綁定方法
相關(guān)文章
jquery操作checkbox的常用方法總結(jié)【附測試源碼下載】
這篇文章主要介紹了jquery操作checkbox的常用方法,結(jié)合完整實例形式總結(jié)分析了jQuery使用checkbox全選、取消、反選等常見操作技巧,并附帶測試源碼供讀者下載參考,需要的朋友可以參考下2019-06-06

