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


Posted in Javascript onFebruary 16, 2017

处理一个列表绑定,因为是一个展示项目,没有使用复杂的插件,直接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动态追加事件的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
Jquery Validation插件防止重复提交表单的解决方法
Mar 05 Javascript
javascript Array数组对象的扩展函数代码
May 22 Javascript
JQuery判断子iframe何时加载完成解决方案
Aug 20 Javascript
ajax+jQuery实现级联显示地址的方法
May 06 Javascript
jQuery移动web开发中的页面初始化与加载事件
Dec 03 Javascript
学习Javascript闭包(Closure)知识
Aug 07 Javascript
为jQuery-easyui的tab组件添加右键菜单功能的简单实例
Oct 10 Javascript
Angular的$http的ajax的请求操作(推荐)
Jan 10 Javascript
基于vue.js中事件修饰符.self的用法(详解)
Feb 23 Javascript
React父子组件间的传值的方法
Nov 13 Javascript
五句话帮你轻松搞定js原型链
Dec 09 Javascript
浅谈react useEffect闭包的坑
Jun 08 Javascript
纯js实现html转pdf的简单实例(推荐)
Feb 16 #Javascript
jq给页面添加覆盖层遮罩的实例
Feb 16 #Javascript
基于JavaScript实现全选、不选和反选效果
Feb 15 #Javascript
bootstrap为水平排列的表单和内联表单设置可选的图标
Feb 15 #Javascript
bootstrap中添加额外的图标实例代码
Feb 15 #Javascript
基于JavaScript实现轮播图原理及示例
Apr 10 #Javascript
js实现模糊匹配功能
Feb 15 #Javascript
You might like
树型结构列出指定目录里所有文件的PHP类
2006/10/09 PHP
体育彩票排列三组选三算法分享
2014/03/07 PHP
windows7下安装php的php-ssh2扩展教程
2014/07/04 PHP
Nginx服务器上安装并配置PHPMyAdmin的教程
2015/08/18 PHP
浅析Yii2中GridView常见操作
2016/04/22 PHP
简明json介绍
2008/09/28 Javascript
JQuery在光标位置插入内容的实现代码
2010/06/18 Javascript
基于JQuery实现相同内容合并单元格的代码
2011/01/12 Javascript
基于jquery实现漂亮的动态信息提示效果
2011/08/02 Javascript
js批量设置样式的三种方法不推荐使用with
2013/02/25 Javascript
JS中的this变量的使用介绍
2013/10/21 Javascript
Jquery 实现grid绑定模板
2015/01/28 Javascript
基于JavaScript实现类似于百度学术高级检索功能
2016/03/02 Javascript
JavaScript中的继承之类继承
2016/05/01 Javascript
JS弹出窗口插件zDialog简单用法示例
2016/06/12 Javascript
Javascript的console['']常用输入方法汇总
2018/04/26 Javascript
模块化react-router配置方法详解
2019/06/03 Javascript
vue.js this.$router.push获取不到params参数问题
2020/03/03 Javascript
[05:05]第三天的dota2
2013/07/29 DOTA
在Apache服务器上同时运行多个Django程序的方法
2015/07/22 Python
selenium python浏览器多窗口处理代码示例
2018/01/15 Python
通过cmd进入python的实例操作
2019/06/26 Python
详解Python 中sys.stdin.readline()的用法
2019/09/12 Python
Python如何通过Flask-Mail发送电子邮件
2020/01/29 Python
python通用数据库操作工具 pydbclib的使用简介
2020/12/21 Python
如何用用Python将地址标记在地图上
2021/02/07 Python
HTML5安全介绍之内容安全策略(CSP)简介
2012/07/10 HTML / CSS
千元咖啡店的创业计划书范文
2013/12/29 职场文书
水果连锁超市创业计划书
2014/01/24 职场文书
学习优秀共产党员先进事迹思想报告
2014/09/17 职场文书
副乡长群众路线教育实践活动个人对照检查材料
2014/09/19 职场文书
司法工作人员群众路线对照检查材料思想汇报
2014/09/30 职场文书
2015年国庆节广播稿
2015/08/19 职场文书
经典哲理警句:志不真则心不热,心不热则功不贤
2019/11/14 职场文书
读《儒林外史》有感:少一些功利,多一些真诚
2020/01/19 职场文书
React Hook用法示例详解(6个常见hook)
2021/04/28 Javascript