关于动态生成dom绑定事件失效的原因及解决方法


Posted in Javascript onAugust 06, 2016

之前做项目都是直接用jquery的bind绑定事件,不过当时都不是动态生成dom元素,而是已经页面中原本存在的dom元素进行事件绑定,最近在测试给动态生成的dom绑定事件的时候发现事件失效,于是就测试了一下:

1. 事件失效的原因:

(1)bind事件绑定只对dom中存在的元素有效,对于我们后来动态增加的元素是监测不到,所以绑定不了

(2)同样,当你使用var aa = document.getElementsByTagName("动态生成的元素");来获取动态生成的元素的时候也是获取不到的,因为网页只会执行一次初始化绑定,之后动态生成的dom元素也是监测不到的。

2. 解决办法:

(1)在每一个动态生成的地方都再绑定多一次事件,比如这个博客里面的例子

(2)把bind改用live,因为live是实时监测的,对于新增的dom元素也是有效的(因为不断去绑定、判断,所以可能会影响Web性能问题)

(3)把bind改用delegate,因为delegate是实时监测的。

(4)在jquery1.7 起版本用on替代了bind()、live() 和 delegate() 方法。

3. 关于最近遇到的事件失效的原因:在原本的网页中(代码可见https://github.com/UFOwl/ife/tree/master/stage02/task16),我想要获取table里面动态生成的删除按钮,帮删除按钮绑定删除时间,可是删除事件失效,因为删除按钮是动态生成的,初始化事件绑定的时候,获取到的table里面的button已经是空的,所以绑定的一直都是空元素,所以点击button按钮的时候一直没有反应。

4. 最后的解决办法:先获取table,然后再绑定table的click事件(因为table是在原本已经存在的dom元素),然后当点击事件触发的时候再捕获事件的target(比如点击table里面的button,这个时候因为已经动态生成button并append进去table里面了,所以button是存在的,此时target指的是button),然后再进行相应的操作。

注意:在这里注意两个问题:

(1)table里面的元素是已经添加进入table里面了的,所以点击那个button的时候,e.target获取到的就是button

(2)为什么已经将button这些元素添加进入table里面,可是还是没能获取到呢,因为是init()这个函数初始化的时候获取table里面的button,可是此时还未进行任何操作,所以获取到的就是空,所以没绑定任何元素。

上面需要注意的两个问题要分清楚,这个是问题的关键。

5.关于bind:每次绑定事件之后事件会一直绑定着,除非用unbind解绑之后再重新绑定,要不然事件会一直存在,所以这就是为什么在做项目的时候,有时候ajax请求的结果会出现1,2,4,8这样叠加,是因为如果用了bind,每次触发事件都会绑定一次操作,所以触发第一次的时候,ajax请求一次;第二次的时候,ajax请求1+1=2次;第三次就是1+2+1=4次;第四次就是1+2+4+1=8次,以此类推。所以如果利用bind绑定事件的话,要先unbind解绑元素原本有的事件再绑定事件,才不会导致ajax请求多次。

以上这篇关于动态生成dom绑定事件失效的原因及解决方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jquery异步循环获取功能实现代码
Sep 19 Javascript
Egret引擎开发指南之创建项目
Sep 03 Javascript
jQuery实现本地预览上传图片功能
Jan 08 Javascript
jquery checkbox无法用attr()二次勾选问题的解决方法
Jul 22 Javascript
AngularJS服务service用法总结
Dec 13 Javascript
Vue.js 表单控件操作小结
Mar 29 Javascript
解决vue-quill-editor上传内容由于图片是base64的导致字符太长的问题
Aug 20 Javascript
express+vue+mongodb+session 实现注册登录功能
Dec 06 Javascript
elementui之el-tebs浏览器卡死的问题和使用报错未注册问题
Jul 06 Javascript
使用JavaScript实现网页秒表功能(含开始、暂停、继续、重置功能)
Jun 05 Javascript
js实现全选和全不选功能
Jul 28 Javascript
uniapp开发小程序实现滑动页面控制元素的显示和隐藏效果
Dec 10 Javascript
深入理解JS DOM事件机制
Aug 06 #Javascript
jQuery插件Easyui设置datagrid的pageNumber导致两次请求问题的解决方法
Aug 06 #Javascript
用JS写的一个Ajax库(实例代码)
Aug 06 #Javascript
angularJS 如何读写缓冲的方法(推荐)
Aug 06 #Javascript
JS获取和修改元素样式的实例代码
Aug 06 #Javascript
原生js获取元素样式的简单方法
Aug 06 #Javascript
浅析Node.js实现HTTP文件下载
Aug 05 #Javascript
You might like
第一节--面向对象编程
2006/11/16 PHP
PHP 正则表达式小结
2015/02/12 PHP
PHP版本如何选择?应该使用哪个版本?
2015/05/13 PHP
PHP 裁剪图片
2021/03/09 PHP
jquery.cookie用法详细解析
2013/12/18 Javascript
Javascript 按位左移运算符使用介绍(
2014/02/04 Javascript
JavaScript中的对象的extensible属性介绍
2014/12/30 Javascript
jQuery之DOM对象和jQuery对象的转换与区别分析
2015/01/08 Javascript
jQueryMobile之Helloworld与页面切换的方法
2015/02/04 Javascript
JS实现双击编辑可修改状态的方法
2015/08/14 Javascript
JavaScript与java语言有什么不同
2016/09/22 Javascript
js改变html的原有内容实现方法
2016/10/05 Javascript
详解Node.js开发中的express-session
2017/05/19 Javascript
VUE简单的定时器实时刷新的实现方法
2019/01/20 Javascript
django中使用vue.js的要点总结
2019/07/07 Javascript
koa2 从入门到精通(小结)
2019/07/23 Javascript
Vue form表单动态添加组件实战案例
2019/09/02 Javascript
js实现九宫格抽奖
2020/03/19 Javascript
Tensorflow使用支持向量机拟合线性回归
2018/09/07 Python
python使用for循环计算0-100的整数的和方法
2019/02/01 Python
python3实现的zip格式压缩文件夹操作示例
2019/08/17 Python
python 多进程并行编程 ProcessPoolExecutor的实现
2019/10/11 Python
Python函数基本使用原理详解
2020/03/19 Python
关于django python manage.py startapp 应用名出错异常原因解析
2020/12/15 Python
收集的22款给力的HTML5和CSS3帮助工具
2012/09/14 HTML / CSS
意大利大型购物中心:Oliviero.it
2017/10/19 全球购物
南非最大的在线时尚商店:Zando
2019/07/21 全球购物
希腊品牌鞋类销售网站:epapoutsia.gr
2020/03/18 全球购物
宿舍卫生检讨书
2014/01/16 职场文书
新学期开学标语2015
2015/07/16 职场文书
MySQL infobright的安装步骤
2021/04/07 MySQL
MySQL Threads_running飙升与慢查询的相关问题解决
2021/05/08 MySQL
springboot+VUE实现登录注册
2021/05/27 Vue.js
SqlServer数据库远程连接案例教程
2021/07/15 SQL Server
div与span之间的区别与使用介绍
2021/12/06 HTML / CSS
一文了解MYSQL三大范式和表约束
2022/04/03 MySQL