您的位置:首页 > Web前端 > JQuery

jQuery为DOM动态追加事件的方法

2017-12-12 10:11 148 查看
append插入的dom绑定事件:

最初是这样写的:

$(".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