js事件机制----捕获与冒泡机制实例分析


Posted in Javascript onMay 22, 2020

本文实例讲述了js事件机制----捕获与冒泡机制。分享给大家供大家参考,具体如下:

先从事件绑定机制说起, 事件绑定机制通过绑定方法addEventListener()实现,

语法格式如下:

element.addEventListener(event, function, useCapture)

参数值

参数 描述
event 必须。字符串,指定事件名。注意: 不要使用 "on" 前缀。 例如,使用 "click" ,而不是使用 "onclick"。 提示: 所有 HTML DOM 事件,可以查看我们完整的 HTML DOM Event 对象参考手册。
function 必须。指定要事件触发时执行的函数。  当事件对象会作为第一个参数传入函数。 事件对象的类型取决于特定的事件。例如, "click" 事件属于 MouseEvent(鼠标事件) 对象。
useCapture 可选。布尔值,指定事件是否在捕获或冒泡阶段执行。 可能值: true - 事件句柄在捕获阶段执行 false- false- 默认。事件句柄在冒泡阶段执行

我们可以看到第三个参数是布尔值, true表示在捕获阶段执行, 而false指在冒泡阶段执行

所以什么是 捕获和冒泡?

捕获(capture)和冒泡(bubble)是事件传播过程中的两个概念, 比如用户单击某个元素, 但由于元素处于父元素内, 该父元素又处于document对象中, document对象又处于window对象中, 因此该单击事件实际发生在该元素, 父元素, document, window对象上, 而事件传播过程就是浏览器决定依次触发哪个对象的事件处理函数的过程.

DOM事件模型将事件传播过程分为两个阶段: 捕获阶段和冒泡阶段

在事件捕获阶段, 事件从最顶级的父元素逐层向内传递,

在冒泡阶段, 事件从事件发生的直接元素 , 逐层向父元素传递

js事件机制----捕获与冒泡机制实例分析

这里举个简单的例子:

点击孙子元素, 给body中的元素都添加点击事件并输出触发事件的对象id:

<!DOCTYPE html>
<html>
<head>
</head>
<body>
 <div id="父级">
 <div id="儿子">
  <div id="孙子" style="width:100px; height:100px; background-color:yellow">
  </div>
 </div>
 </div>
</body>
<script type="text/javascript">
 var a = document.getElementById('父级'),
 b = document.getElementById('儿子'),
 c = document.getElementById('孙子');
 a.addEventListener("click",show, true);
 b.addEventListener("click",show, true);
 c.addEventListener("click",show, true);
 console.log("前3为捕获,后三个为冒泡");
 a.addEventListener("click",show, false);
 b.addEventListener("click",show, false);
 c.addEventListener("click",show, false);
 function show(even){ console.log(this.id); }
</script>
</html>

js事件机制----捕获与冒泡机制实例分析

其中两条孙子输出相同被折叠了, 可以看到前三个是以捕获顺序, 第三个参数为true, 顺序是从父亲到孙子

后三个为false意思是冒泡顺序, 顺序是孙子到父级,即从内到外

实际上捕获和冒泡时最外层和的元素并不是父级div,

捕获时实际上是:

document-->html-->body-->父级div-->儿子div-->孙子div

冒泡时相反, 只不过body及以上没添加事件并输出, 所以在例子中没显现出来

所以用冒泡还是捕获?

对于事件代理来说,在事件捕获或者事件冒泡阶段处理并没有明显的优劣之分,但是由于事件冒泡的事件流模型被所有主流的浏览器兼容,从兼容性角度来说还是建议大家使用事件冒泡模型。

感兴趣的朋友可以使用在线HTML/CSS/JavaScript代码运行工具:http://tools.3water.com/code/HtmlJsRun测试上述代码运行效果。

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
让iframe框架网页在任何浏览器下自动伸缩
Aug 18 Javascript
[原创]提供复制本站内容时出现,该文章转自脚本之家等字样的js代码
Mar 27 Javascript
javascript同页面多次调用弹出层具体实例代码
Aug 16 Javascript
JavaScript中读取和保存文件实例
May 08 Javascript
浅谈JavaScript function函数种类
Dec 29 Javascript
Javascript页面跳转常见实现方式汇总
Nov 28 Javascript
Bootstrap每天必学之js插件
Nov 30 Javascript
JS实现的汉字与Unicode码相互转化功能分析
May 25 Javascript
深入理解与使用keep-alive(配合router-view缓存整个路由页面)
Sep 25 Javascript
使用jQuery动态设置单选框的选中效果
Dec 06 jQuery
Vue+Koa2 打包后进行线上部署的教程详解
Jul 31 Javascript
利用d3.js制作连线动画图与编辑器的方法实例
Sep 05 Javascript
JavaScript使用prototype属性实现继承操作示例
May 22 #Javascript
详解如何修改 node_modules 里的文件
May 22 #Javascript
Node.js API详解之 readline模块用法详解
May 22 #Javascript
vue+canvas实现移动端手写签名
May 21 #Javascript
基于canvas实现手写签名(vue)
May 21 #Javascript
jQuery实现移动端笔触canvas电子签名
May 21 #jQuery
js cavans实现静态滚动弹幕
May 21 #Javascript
You might like
让codeigniter与swfupload整合的最佳解决方案
2014/06/12 PHP
php验证session无效的解决方法
2014/11/04 PHP
ThinkPHP水印功能实现修复PNG透明水印并增加JPEG图片质量可调整
2014/11/05 PHP
php通过exif_read_data函数获取图片的exif信息
2015/05/21 PHP
php实现批量删除挂马文件及批量替换页面内容完整实例
2016/07/08 PHP
php 删除指定文件夹的实例讲解
2017/07/25 PHP
PHP使用Curl实现模拟登录及抓取数据功能示例
2018/04/27 PHP
PHP PDOStatement::fetchObject讲解
2019/02/01 PHP
在laravel框架中实现封装公共方法全局调用
2019/10/14 PHP
javascript闭包的理解和实例
2010/08/12 Javascript
JavaScript动态调整TextArea高度的代码
2010/12/28 Javascript
javascript判断用户浏览器插件安装情况的代码
2011/01/01 Javascript
调用innerHTML之后onclick失效问题的解决方法
2014/01/28 Javascript
jQuery函数map()和each()介绍及异同点分析
2014/11/08 Javascript
JavaScript使用yield模拟多线程的方法
2015/03/19 Javascript
浅谈Javascript的静态属性和原型属性
2015/05/07 Javascript
JavaScript调用浏览器打印功能实例分析
2015/07/17 Javascript
AngularJs Dependency Injection(DI,依赖注入)
2016/09/02 Javascript
getElementById().innerHTML与getElementById().value的区别
2016/10/27 Javascript
js仿微信语音播放实现思路
2016/12/12 Javascript
vue动态生成dom并且自动绑定事件
2017/04/19 Javascript
jQuery鼠标移动图片上实现放大效果
2017/06/25 jQuery
完美解决手机浏览器顶部下拉出现网页源或刷新的问题
2017/11/30 Javascript
JavaScript学习笔记之DOM基础操作实例小结
2019/01/09 Javascript
JQuery实现折叠式菜单的详细代码
2020/06/03 jQuery
js 图片懒加载的实现
2020/10/21 Javascript
python实现判断数组是否包含指定元素的方法
2015/07/15 Python
将Python代码打包为jar软件的简单方法
2015/08/04 Python
Python使用pyodbc访问数据库操作方法详解
2018/07/05 Python
让Python脚本暂停执行的几种方法(小结)
2019/07/11 Python
Pytorch提取模型特征向量保存至csv的例子
2020/01/03 Python
Python 实现PS滤镜中的径向模糊特效
2020/12/03 Python
HTML5微信播放全屏问题的解决方法
2017/03/09 HTML / CSS
品质主管的岗位职责
2013/12/04 职场文书
社区党员公开承诺书
2014/08/30 职场文书
2015年小学数学教师个人工作总结
2015/05/25 职场文书