javascript事件监听与事件委托实例详解
前端  /  管理员 发布于 4年前   244
本文实例讲述了javascript事件监听与事件委托。分享给大家供大家参考,具体如下:
事件监听与事件委托
在js中,常用到element.addEventListener()
来进行事件的监听。但是当页面中存在大量需要绑定事件的元素时,这种方式可能会带来性能影响。此时,我们可以用事件委托的方式来进行事件的监听。
每个事件都经历三个阶段
事件委托需要用到事件的冒泡,冒泡就是事件发生时,上层会一层一层的接收这个事件。
如下页面结构:
当点击按钮,首先button接收到事件,然后向上层冒泡,接着
id="div1"
接收到事件,接着是id="div2"
,一直到达document的顶层。所以可以添加一个事件处理器到父级,由他接收所有子节点的事件信息。这就是事件委托。
事件监听与事件委托性能比较
通过构建若干个button元素,并为其绑定事件监听器来比较事件监听与事件委托的性能。
1.构建若干个button元素,并添加到body中
此时页面生成了100个按钮,id为0到99,class为'btn';fragment是一个文档片段,相比较下面这种代码的好处是
for(var i = 0;i<100;i++){ var btn=document.createElement('button'); body.appendChild(btn);}前者页面只重排一次,后者页面重排了100次;所以若遇到大模块添加dom时,最好使用fragment
2.为button绑定事件监听器,并设置时间戳
var btn = document.querySelectorAll('.btn');var date1 = new Date();for (var i = 0; i < btn.length; i++) { (function(i) { btn[i].addEventListener('click', function() { console.log(i); }); })(i)}3.给body绑定click事件,实现事件的委托
var date2 = new Date();body.addEventListener('click', function(e) { var element = e.target; if (element.className == 'btn') { console.log(element.id); }})var date3 = new Date();下面我们来通过时间戳分析一下这两种方式的性能。
console.log(date2 - date1);console.log(date3 - date1);通过改变button的数量,得到以下数据(单位:ms):
在360兼容模式下:
- 当button数量为100时,平均为 6 0
- 当button数量为400时,平均为 20 0
- 当button数量为1000时,平均为 48 0
在新版谷歌下:
- 当button数量为1000时,平均为 3 0
可见当页面中有大量元素需要绑定事件时,并不是所有的事件都会被触发,而这时对所有需要监听的元素都绑定事件处理器无疑是要花费代价的,而通过事件委托的方式可以很好的解决性能问题,不需要为每个元素都绑定事件监听器。但是要写一些逻辑代码来判断事件源。所以,如果你的web项目对性能要求极为苛刻,事件委托也不失于一种优雅的选择
PS:这里再为大家附上javascript系统自带事件参考表供大家参考查询:
javascript事件与功能说明大全:
http://tools..net.cn/table/javascript_event更多关于JavaScript相关内容可查看本站专题:《JavaScript事件相关操作与技巧大全》、《JavaScript常用函数技巧汇总》、《javascript面向对象入门教程》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》及《JavaScript数学运算用法总结》
希望本文所述对大家JavaScript程序设计有所帮助。
您可能感兴趣的文章:
- JS 事件绑定、事件监听、事件委托详细介绍
- js事件监听器用法实例详解
- js事件监听机制(事件捕获)总结
- js实现滑动触屏事件监听的方法
- javascript在事件监听方面的兼容性小结
- js 冒泡事件与事件监听使用分析
- JavaScript绑定事件监听函数的通用方法
- javascript事件委托的方式绑定详解
- JS实现为动态添加的元素增加事件功能示例【基于事件委托】
- JavaScript中的事件委托及好处
- JavaScript动态添加事件之事件委托
- javascript性能优化之事件委托实例详解
122 在
学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..123 在
Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..原梓番博客 在
在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..博主 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..1111 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
Copyright·© 2019 侯体宗版权所有·
粤ICP备20027696号