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继承的实现
Oct 24 Javascript
Javascript Math ceil()、floor()、round()三个函数的区别
Mar 09 Javascript
jquery判断浏览器类型的代码
Nov 05 Javascript
jQuery 淡出一个图像到另一个图像的实现代码
Jun 12 Javascript
javascript代码运行不出来执行错误的可能情况整理
Oct 18 Javascript
jQuery后代选择器用法实例
Dec 23 Javascript
javascript笛卡尔积算法实现方法
Apr 08 Javascript
JavaScript注册时密码强度校验代码
Jun 30 Javascript
bootstrap3-dialog-master模态框使用详解
Aug 22 Javascript
JavaScript中发出HTTP请求最常用的方法
Jul 12 Javascript
react.js组件实现拖拽复制和可排序的示例代码
Aug 20 Javascript
vue进入页面时滚动条始终在底部代码实例
Mar 26 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
Protoss兵种介绍
2020/03/14 星际争霸
Zend Studio for Eclipse的java.lang.NullPointerException错误的解决方法
2008/12/06 PHP
ionCube 一款类似zend的PHP加密/解密工具
2010/07/25 PHP
PHP高自定义性安全验证码代码
2011/11/27 PHP
PHP删除非空目录的函数代码小结
2013/02/28 PHP
详解php用curl调用接口方法,get和post两种方式
2017/01/13 PHP
Yii2-GridView 中让关联字段带搜索和排序功能示例
2017/01/21 PHP
JQuery的ajax获取数据后的处理总结(html,xml,json)
2010/07/14 Javascript
利用javascript解决图片缩放及其优化的代码
2012/05/23 Javascript
js的onload事件及初始化按钮事件示例代码
2013/09/25 Javascript
解决jquery中美元符号命名冲突问题
2014/01/08 Javascript
jQuery学习笔记之jQuery中的$
2015/01/19 Javascript
浅谈javascript基础之客户端事件驱动
2016/06/10 Javascript
Javascript json object 与string 相互转换的简单实现
2016/09/27 Javascript
利用jQuery对无序列表排序的简单方法
2016/10/16 Javascript
H5上传本地图片并预览功能
2017/05/08 Javascript
Nodejs中crypto模块的安全知识讲解
2018/01/03 NodeJs
p5.js入门教程之键盘交互
2018/03/19 Javascript
解决Vue中 父子传值 数据丢失问题
2019/08/27 Javascript
python实现迭代法求方程组的根过程解析
2019/11/25 Javascript
Angular value与ngValue区别详解
2019/11/27 Javascript
Vue自定义render统一项目组弹框功能
2020/06/07 Javascript
解决vue与node模版引擎的渲染标记{{}}(双花括号)冲突问题
2020/09/11 Javascript
Python 实现字符串中指定位置插入一个字符
2018/05/02 Python
Python中文编码知识点
2019/02/18 Python
python取均匀不重复的随机数方式
2019/11/27 Python
Pytorch使用PIL和Numpy将单张图片转为Pytorch张量方式
2020/05/25 Python
python 通过exifread读取照片信息
2020/12/24 Python
ProBikeKit德国:在线公路自行车专家
2018/06/03 全球购物
毕业自荐信
2013/12/16 职场文书
竞选学生会主席演讲稿
2014/04/24 职场文书
荷叶母亲教学反思
2014/04/30 职场文书
团结就是力量演讲稿
2014/05/21 职场文书
节约用电通知
2015/04/25 职场文书
家庭聚会祝酒词
2015/08/11 职场文书
GoLang中生成UUID唯一标识的实现
2021/05/08 Golang