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 相关文章推荐
javascript eval函数深入认识
Feb 21 Javascript
javascript动态加载实现方法一
Aug 22 Javascript
Jquery实现的tab效果可以指定默认显示第几页
Oct 16 Javascript
js为空或不是对象问题的快速解决方法
Dec 11 Javascript
jquery缓动swing liner控制动画过程不同时刻的速度
May 29 Javascript
jQuery选择器总结之常用元素查找方法
Aug 04 Javascript
详解Vue-基本标签和自定义控件
Mar 24 Javascript
AugularJS从入门到实践(必看篇)
Jul 10 Javascript
ReactNative短信验证码倒计时控件的实现代码
Jul 20 Javascript
JavaScript 俄罗斯方块游戏实现方法与代码解释
Apr 08 Javascript
vuex中store存储store.commit和store.dispatch的用法
Jul 24 Javascript
vue路由分文件拆分管理详解
Aug 13 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
thinkphp中memcache的用法实例
2014/11/29 PHP
PHP使用glob函数遍历目录或文件夹的方法
2014/12/16 PHP
PHP实现常用排序算法的方法
2020/02/05 PHP
jQuery实现用户注册的表单验证示例
2013/08/28 Javascript
关于Javascript 对象(object)的prototype
2014/05/09 Javascript
JavaScript异步加载浅析
2014/12/28 Javascript
JS实现同时搜索百度和必应的方法
2015/01/27 Javascript
浅谈angularJS 作用域
2015/07/05 Javascript
jQuery手机拨号界面特效代码分享
2015/08/27 Javascript
jQuery满屏焦点图左右滚动特效代码分享
2015/09/07 Javascript
浅谈JS原型对象和原型链
2016/03/02 Javascript
JavaScript对象数组排序实例方法浅析
2016/06/15 Javascript
Bootstrap基本插件学习笔记之折叠(22)
2016/12/08 Javascript
[js高手之路]设计模式系列课程-发布者,订阅者重构购物车的实例
2017/08/29 Javascript
JS中原始值和引用值的储存方式示例详解
2018/03/23 Javascript
node上的redis调用优化示例详解
2018/10/30 Javascript
JS实现li标签的删除
2019/04/12 Javascript
详解如何在Vue项目中导出Excel
2019/04/19 Javascript
Vue源码解析之数据响应系统的使用
2019/04/24 Javascript
JS画布动态实现黑客帝国背景效果
2020/11/08 Javascript
Python实现查询某个目录下修改时间最新的文件示例
2018/08/29 Python
selenium在执行phantomjs的API并获取执行结果的方法
2018/12/17 Python
解决python xlrd无法读取excel文件的问题
2018/12/25 Python
python实现异常信息堆栈输出到日志文件
2019/12/26 Python
Python中求对数方法总结
2020/03/10 Python
Python闭包与装饰器原理及实例解析
2020/04/30 Python
HTML5+WebSocket实现多文件同时上传的实例
2016/12/29 HTML / CSS
世界上最大的皮肤科医生拥有和经营的美容网站:LovelySkin
2021/01/03 全球购物
大学信息公开实施方案
2014/03/09 职场文书
挂牌仪式策划方案
2014/05/18 职场文书
大学生党员承诺书
2014/05/20 职场文书
铣床操作工岗位职责
2014/06/13 职场文书
群众路线剖析材料范文
2014/10/09 职场文书
2014年测量员工作总结
2014/12/12 职场文书
城南旧事观后感
2015/06/11 职场文书
python文本处理的方案(结巴分词并去除符号)
2021/05/26 Python