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-世界上误解最深的语言分析
Aug 12 Javascript
javascript判断ie浏览器6/7版本加载不同样式表的实现代码
Dec 26 Javascript
checkbox全选所涉及到的知识点介绍
Dec 31 Javascript
jquery实现增加删除行的方法
Feb 03 Javascript
js类式继承与原型式继承详解
Apr 07 Javascript
深入了解JavaScript的逻辑运算符(与、或)
Dec 20 Javascript
Node.js利用Net模块实现多人命令行聊天室的方法
Dec 23 Javascript
JS 学习总结之正则表达式的懒惰性和贪婪性
Jul 03 Javascript
说说node中的可读流和可写流的区别
Jun 01 Javascript
微信小程序文字显示换行问题
Jul 28 Javascript
TypeScript中使用getElementXXX()的示例代码
Sep 12 Javascript
Vue学习笔记之计算属性与侦听器用法
Dec 07 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
239军机修复记
2021/03/02 无线电
CodeIgniter记录错误日志的方法全面总结
2016/05/17 PHP
nodejs 后缀名判断限制代码
2011/03/31 NodeJs
javascript开发随笔二 动态加载js和文件
2011/11/25 Javascript
自己编写的类似JS的trim方法
2013/10/09 Javascript
使用jquery.upload.js实现异步上传示例代码
2014/07/29 Javascript
jQuery如何防止这种冒泡事件发生
2015/02/27 Javascript
使用jQuery实现图片遮罩半透明坠落遮挡
2015/03/16 Javascript
js实现简单选项卡与自动切换效果的方法
2015/04/10 Javascript
JavaScript实现数据类型的相互转换
2016/03/06 Javascript
巧用jQuery选择器提高写表单效率的方法
2016/08/19 Javascript
Javascript的动态增加类的实现方法
2016/10/20 Javascript
Node.js readline模块与util模块的使用
2018/03/01 Javascript
浅析vue-router中params和query的区别
2019/12/24 Javascript
javascript设计模式 ? 组合模式原理与应用实例分析
2020/04/14 Javascript
vue监听dom大小改变案例
2020/07/29 Javascript
[52:29]DOTA2上海特级锦标赛主赛事日 - 2 胜者组第一轮#3Secret VS OG第三局
2016/03/03 DOTA
[05:06]2017亚洲邀请赛DAC回顾片
2017/04/19 DOTA
python实现调用其他python脚本的方法
2014/10/05 Python
python监控文件或目录变化
2016/06/07 Python
Python模块包中__init__.py文件功能分析
2016/06/14 Python
python爬虫入门教程--HTML文本的解析库BeautifulSoup(四)
2017/05/25 Python
flask中使用蓝图将路由分开写在不同文件实例解析
2018/01/19 Python
Python KMeans聚类问题分析
2018/02/23 Python
python、PyTorch图像读取与numpy转换实例
2020/01/13 Python
Django使用Celery加redis执行异步任务的实例内容
2020/02/20 Python
Python Selenium安装及环境配置的实现
2020/03/17 Python
python画环形图的方法
2020/03/25 Python
解决Python spyder显示不全df列和行的问题
2020/04/20 Python
Python 将代码转换为可执行文件脱离python环境运行(步骤详解)
2021/01/25 Python
是什么让J2EE适合用来开发多层的分布式的应用
2015/01/16 面试题
金融学专科生自我鉴定
2014/02/21 职场文书
小学毕业感言500字
2014/02/28 职场文书
初级党校心得体会
2014/09/11 职场文书
生产工厂门卫岗位职责
2014/09/26 职场文书
《打电话》教学反思
2016/02/22 职场文书