jQuery为DOM动态追加事件的⽅法
处理⼀个列表绑定,因为是⼀个展⽰项⽬,没有使⽤复杂的插件,直接jsrender写了个模板,但是后⾯有⼀个操作按钮,去查看数据详情,想到了jquery使⽤on进⾏事件委托,然后就开搞
最初是这样写的:jquery在一个元素后追加标签
$(".btn-open").on("click", function () {
alert($(this).text());
})
当然这样是不起作⽤的,因为在document reday后,.btn-open 这个元素根本还不存在呢,列表没绑定,事件当然也帮不上的!
然后是这样的:
$(".table").on("click", ".btn-open", function () {
alert($(this).text());
})
代码可以看得明⽩,到.table 元素,给.btn-open 追加 click事件。⼀般来说这样就可以了。但是依然不⾏,我勒个去,我开始怀疑⾃⼰的记忆了。然后去了下⽂档。
⽂档说:
事件处理只能绑定在当前被选中的元素上;⽽且,在您的代码调⽤.on()的时候,他们必须在页⾯⽂档中已经存在。
好吧,在document ready时,.table确实不存在,所以还要继续改
$(document).on("click", ".btn-open", function () {
alert($(this).text());
})
终于可以⼯作了。
总结:
1.jQuery委托事件与直接绑定事件的区别:
$(“X”).on(“click”,function(){})
$(“X”).on(“click”,”选择X的⼦元素”,function(){})
2.事件处理只能绑定到当前存在的元素⾝上,也就是第⼀个选择器中的内容必须当前存在(这也是为什么第⼆段代码不起作⽤的原因,因为.table不存在),所以保险起见,可以直接绑定委托事件到document上。
以前⼀直没有仔细的阅读⽂档,对这⼀块模棱两可,今天弄清楚并记录下来。
以上这篇jQuery为DOM动态追加事件的⽅法就是⼩编分享给⼤家的全部内容了,希望能给⼤家⼀个参考,也希望⼤家多多⽀持。