jQuery为DOM动态追加事件的方法
2017-12-12 10:11
148 查看
append插入的dom绑定事件:
最初是这样写的:
当然这样是不起作用的,因为在document reday后,.btn-open 这个元素根本还不存在呢,列表没绑定,事件当然也帮不上的!
然后是这样的:
代码可以看得明白,找到.table 元素,给.btn-open 追加 click事件。一般来说这样就可以了。但是依然不行,我勒个去,我开始怀疑自己的记忆了。然后去找了下文档。
文档说:
**
事件处理只能绑定在当前被选中的元素上;而且,在您的代码调用.on()的时候,他们必须在页面文档中已经存在。
**
好吧,在document ready时,.table确实不存在,所以 还要继续改
终于可以工作了。
总结:
1.jQuery委托事件与直接绑定事件的区别:
$(“X”).on(“click”,function(){})
$(“X”).on(“click”,”选择X的子元素”,function(){}) x的子元素触发事件 “`
[b]*2.事件处理只能绑定到当前存在的元素身上,也就是第一个选择器中的内容必须当前存在*[/b](这也是为什么第二段代码不起作用的原因,因为.table不存在),所以保险起见,可以直接绑定委托事件到document上。
原文请阅读:http://www.jb51.net/article/105736.htm
最初是这样写的:
$(".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(){}) x的子元素触发事件 “`
[b]*2.事件处理只能绑定到当前存在的元素身上,也就是第一个选择器中的内容必须当前存在*[/b](这也是为什么第二段代码不起作用的原因,因为.table不存在),所以保险起见,可以直接绑定委托事件到document上。
原文请阅读:http://www.jb51.net/article/105736.htm
相关文章推荐
- jQuery为DOM动态追加事件的方法
- jQuery2.x以上版本对动态新增的DOM元素绑定事件方法
- jQuery为DOM动态追加事件
- 关于jquery中动态增加select,事件无效的快速解决方法
- 动态生成的DOM不会触发onclick事件的原因及解决方法
- JQuery DOM元素方法跟JQuery 核心函数跟JQuery 事件方法
- JQuery为页面Dom元素绑定事件及解除绑定方法
- 关于动态生成dom绑定事件失效的原因及解决方法
- 详解jQuery向动态生成的内容添加事件响应jQuery live()方法
- jQuery为动态生成的select元素添加事件的方法
- jQuery动态添加的元素绑定事件处理函数代码的方法及比较
- jquery动态生成的元素添加事件的方法
- 【笔记】jQuery中on()与delegate()方法给动态添加元素绑定事件
- 动态生成的html中无法使用jquery事件的解决方法
- jQuery为动态生成的select元素添加事件的方法
- jquery live方法,解决jquery动态添加按钮无法触发点击事件的问题
- jQuery给动态添加的元素绑定事件的方法
- JQuery入门总结(一)【DOM、选择器、方法事件】
- 微信公众平台接口 动态生成html图片预览无法使用jquery事件的解决方法