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 相关文章推荐
javascript针对DOM的应用实例(一)
Apr 15 Javascript
使用js解决由border属性引起的div宽度问题
Nov 26 Javascript
js、jquery图片动画、动态切换示例代码
Jun 03 Javascript
jquery让指定的元素闪烁显示的方法
Mar 17 Javascript
每日十条JavaScript经验技巧(一)
Jun 23 Javascript
BootStrap中Table分页插件使用详解
Oct 09 Javascript
简单实现js菜单栏切换效果
Mar 04 Javascript
Node.js如何优雅的封装一个实用函数的npm包的方法
Apr 29 Javascript
JavaScript函数式编程(Functional Programming)纯函数用法分析
May 22 Javascript
如何利用Node.js与JSON搭建简单的动态服务器
Jun 16 Javascript
JS继承实现方法及优缺点详解
Sep 02 Javascript
jquery实现点击左右按钮切换图片
Jan 27 jQuery
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
dhtmlxTree目录树增加右键菜单以及拖拽排序的实现方法
2013/04/26 PHP
php为字符串前后添加指定数量字符的方法
2015/05/04 PHP
PHP序列化/对象注入漏洞分析
2016/04/18 PHP
PHP入门教程之正则表达式基本用法实例详解(正则匹配,搜索,分割等)
2016/09/11 PHP
详解PHP5.6.30与Apache2.4.x配置
2017/06/02 PHP
javascript高亮效果的二种实现方法
2008/09/14 Javascript
jQuery学习笔记 更改jQuery对象
2012/09/19 Javascript
用Js实现的动态增加表格示例自己写的
2013/10/21 Javascript
JS简单实现登陆验证附效果图
2013/11/19 Javascript
浅谈JavaScript数据类型及转换
2015/02/28 Javascript
js实现三张图(文)片一起切换的banner焦点图
2015/08/25 Javascript
jQuery绑定事件监听bind和移除事件监听unbind用法实例详解
2016/01/19 Javascript
jQuery侧边栏实现代码
2016/05/06 Javascript
Javascript 函数的四种调用模式
2016/11/05 Javascript
实例解析jQuery中如何取消后续执行内容
2016/12/01 Javascript
基于ES6 Array.of的用法(实例讲解)
2017/09/05 Javascript
JavaScript 中Date对象的格式化代码方法汇总
2017/09/06 Javascript
canvas轨迹回放功能实现
2017/12/20 Javascript
jQuery代码优化方法总结
2018/01/29 jQuery
mpvue小程序仿qq左滑置顶删除组件
2018/08/03 Javascript
vue 解决addRoutes多次添加路由重复的操作
2020/08/04 Javascript
[44:39]2014 DOTA2国际邀请赛中国区预选赛 NE VS CNB
2014/05/21 DOTA
wxpython 学习笔记 第一天
2009/03/16 Python
Python实现处理管道的方法
2015/06/04 Python
浅谈python中的__init__、__new__和__call__方法
2017/07/18 Python
python 读取txt中每行数据,并且保存到excel中的实例
2018/04/29 Python
python使用flask与js进行前后台交互的例子
2019/07/19 Python
Python适配器模式代码实现解析
2019/08/02 Python
使用Bazel编译TensorBoard教程
2020/02/15 Python
python获取linux系统信息的三种方法
2020/10/14 Python
应届生如何写自荐信
2014/01/05 职场文书
小区物业门卫岗位职责
2014/04/10 职场文书
家长写给孩子的评语
2014/04/18 职场文书
技校毕业生自荐书
2014/05/23 职场文书
中学生社区服务活动报告
2015/02/05 职场文书
个人求职自荐信范文
2015/03/06 职场文书