jQuery为DOM动态追加事件
2017-07-03 00:00
99 查看
处理一个列表绑定,因为是一个展示项目,没有使用复杂的插件,直接jsrender写了个模板,但是后面有一个操作按钮,去查看数据详情,想到了jquery使用on进行事件委托,然后就开搞
最初是这样写的:$(".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动态追加事件的方法
- jQuery为DOM动态追加事件的方法
- 关于jquery 的绑定事件on 如何绑定动态生成的dom元素
- jquery实现级联遇到的ajax同步请求、动态DOM元素监听事件
- 工作积累(六)——jQuery实现DOM元素事件动态绑定
- JQuery动态生成的dom绑定事件
- Jquery给Dom 动态绑定事件
- 工作积累(六)——jQuery实现DOM元素事件动态绑定
- JQuery 动态添加DOM元素及事件响应机制的2点注意
- jQuery动态追加页面数据以及事件委托详解
- jquery给动态添加的dom元素绑定事件
- Jquery 动态添加dom后,再为其绑定事件
- 案例十一 、使用jQuery动态追加页面数据以及事件委托
- jQuery 新版本的 Dom 元素动态绑定事件
- jquery给动态dom绑定事件
- jQuery2.x以上版本对动态新增的DOM元素绑定事件方法
- JQuery给动态生成的DOM元素绑定点击事件
- 如何让动态创建的页面元素响应用户事件 (HTML/javascript/jQuery/Ajax/DOM)
- javascript,jquery动态添加dom元素,并设定css属性,点击事件
- jQuery动态添加的元素绑定事件处理函数代码