关于动态生成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 相关文章推荐
JS启动应用程序的一个简单例子
May 11 Javascript
Javascript事件热键兼容ie|firefox
Dec 30 Javascript
JavaScript使用IEEE 标准进行二进制浮点运算产生莫名错误的解决方法
May 28 Javascript
详谈 Jquery Ajax异步处理Json数据.
Sep 09 Javascript
自编jQuery插件实现模拟alert和confirm
Sep 01 Javascript
javascript算法题:求任意一个1-9位不重复的N位数在该组合中的大小排列序号
Apr 01 Javascript
用Vue.js实现监听属性的变化
Nov 17 Javascript
详解Angular Reactive Form 表单验证
Jul 06 Javascript
基于Swiper实现移动端页面图片轮播效果
Dec 28 Javascript
解决IE11 vue +webpack 项目中数据更新后页面没有刷新的问题
Sep 25 Javascript
vue-router之nuxt动态路由设置的两种方法小结
Sep 26 Javascript
js前端面试常见浏览器缓存强缓存及协商缓存实例
Jun 21 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
全国FM电台频率大全 - 30 宁夏回族自治区
2020/03/11 无线电
使用php伪造referer的方法 利用referer防止图片盗链
2014/01/20 PHP
PHP定时更新程序设计思路分享
2014/06/10 PHP
PHP提示Cannot modify header information - headers already sent by解决方法
2014/09/22 PHP
php通过rmdir删除目录的简单用法
2015/03/18 PHP
js数字输入框(包括最大值最小值限制和四舍五入)
2009/11/24 Javascript
JQUERY1.6 使用方法四 检测浏览器
2011/11/23 Javascript
JavaScript高级程序设计 读书笔记之十一 内置对象Global
2012/03/07 Javascript
《JavaScript DOM 编程艺术》读书笔记之JavaScript 语法
2015/01/09 Javascript
JavaScript基础知识点归纳(推荐)
2016/07/09 Javascript
jq stop()和:is(:animated)的用法及区别(详解)
2017/02/12 Javascript
利用vue组件自定义v-model实现一个Tab组件方法示例
2017/12/06 Javascript
微信小程序实现发送验证码按钮效果
2018/12/20 Javascript
深入解读Node.js中的koa源码
2019/06/17 Javascript
javascript自定义日期比较函数用法示例
2019/07/22 Javascript
vue-cli3+typescript新建一个项目的思路分析
2019/08/06 Javascript
Vue过渡效果之CSS过渡详解(结合transition,animation,animate.css)
2020/02/05 Javascript
JavaScript实现轮播图片完整代码
2020/03/07 Javascript
js节流防抖应用场景,以及在vue中节流防抖的具体实现操作
2020/09/21 Javascript
Django使用Mysql数据库已经存在的数据表方法
2018/05/27 Python
Python设计模式之享元模式原理与用法实例分析
2019/01/11 Python
33个Python爬虫项目实战(推荐)
2019/07/08 Python
python 实现一个简单的线性回归案例
2020/12/17 Python
CSS3弹性盒模型开发笔记(一)
2016/04/26 HTML / CSS
印尼在线精品店:Berrybenka.com
2016/10/22 全球购物
Michael Kors美国官网:美式奢侈生活风格的代表
2016/11/25 全球购物
Converse匡威法国官网:美国著名帆布鞋品牌
2018/12/05 全球购物
医学生自荐信
2013/12/03 职场文书
中国央视网签名寄语
2014/01/18 职场文书
房地产公司见习自我鉴定
2014/04/28 职场文书
公司投资建议书
2014/05/16 职场文书
2014医学院领导班子对照检查材料思想汇报
2014/09/19 职场文书
KTV门卫岗位职责
2014/10/09 职场文书
党员批评与自我批评发言稿
2014/10/14 职场文书
《童年的发现》教学反思
2016/02/18 职场文书
MySQL 使用SQL语句修改表名的实现
2021/04/07 MySQL