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 相关文章推荐
Colortip基于jquery的信息提示框插件在IE6下面的显示问题修正方法
Dec 06 Javascript
jquery ajax return没有返回值的解决方法
Oct 20 Javascript
jQuery获得内容和属性示例代码
Jan 16 Javascript
JQuery each()嵌套使用小结
Apr 18 Javascript
js实现跨域访问的三种方法
Dec 09 Javascript
微信小程序 wxapp画布 canvas详细介绍
Oct 31 Javascript
原生js实现图片放大缩小计时器效果
Jan 20 Javascript
详解Vue.js组件可复用性的混合(mixin)方式和自定义指令
Sep 06 Javascript
在vue项目创建的后初始化首次使用stylus安装方法分享
Jan 25 Javascript
vue中使用axios post上传头像/图片并实时显示到页面的方法
Sep 27 Javascript
Angular使用Restful的增删改
Dec 28 Javascript
小程序实现背景音乐播放和暂停
Jun 19 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
PHP中开发XML应用程序之基础篇 添加节点 删除节点 查询节点 查询节
2010/07/09 PHP
input file获得文件根目录简单实现
2013/04/26 PHP
PHP5中GD库生成图形验证码(有汉字)
2013/07/28 PHP
浅谈php数组array_change_key_case() 函数和array_chunk()函数
2016/10/22 PHP
jquery 子窗口操作父窗口的代码
2009/09/21 Javascript
js读取本地excel文档数据的代码
2010/11/11 Javascript
JavaScript高级程序设计 阅读笔记(十三) js定义类或对象
2012/08/14 Javascript
js获得鼠标的坐标值的方法
2013/03/13 Javascript
jquery实现图片渐变切换兼容ie6/Chrome/Firefox
2013/08/02 Javascript
jquery中html、val与text三者属性取值的联系与区别介绍
2013/12/29 Javascript
js查看一个函数的执行时间实例代码
2015/09/12 Javascript
jquery mobile 移动web(5)
2015/12/20 Javascript
JS弹出新窗口被拦截的解决方法
2016/08/09 Javascript
JavaScript中关于iframe滚动条的去除和保留
2016/11/17 Javascript
vue中v-cloak解决刷新或者加载出现闪烁问题(显示变量)
2018/04/20 Javascript
解决vant title-active-color与title-inactive-color不生效问题
2020/11/03 Javascript
python使用datetime模块计算各种时间间隔的方法
2015/03/24 Python
Python的Flask框架中Flask-Admin库的简单入门指引
2015/04/07 Python
解密Python中的描述符(descriptor)
2015/06/03 Python
Python面向对象编程中关于类和方法的学习笔记
2016/06/30 Python
在Python中执行系统命令的方法示例详解
2017/09/14 Python
Python基于多线程实现抓取数据存入数据库的方法
2018/06/22 Python
Python常用模块logging——日志输出功能(示例代码)
2019/11/20 Python
Pandas+Matplotlib 箱式图异常值分析示例
2019/12/09 Python
美国一家著名的儿童鞋制造商:Stride Rite
2017/01/02 全球购物
海蓝之谜(LA MER)澳大利亚官方商城:全球高端奢华护肤品牌
2017/10/27 全球购物
Nili Lotan官网:Nili Lotan同名品牌
2018/01/07 全球购物
考博自荐信
2013/10/25 职场文书
师范学院教师自荐书
2014/01/31 职场文书
机关党员四风问题个人整改措施
2014/10/26 职场文书
12.4全国法制宣传日活动方案
2014/11/02 职场文书
党的群众路线教育实践活动学习笔记
2014/11/05 职场文书
2014年小学教导处工作总结
2014/12/19 职场文书
人事行政部各岗位职责说明书!
2019/07/15 职场文书
pytorch MSELoss计算平均的实现方法
2021/05/12 Python
Apache Hudi 加速传统的批处理模式
2022/04/24 Servers