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 css styleFloat和cssFloat
Mar 15 Javascript
struts2+jquery组合验证注册用户是否存在
Apr 30 Javascript
javascript实现全局匹配并替换的方法
Apr 27 Javascript
javascript实现label标签跳出循环操作
Mar 06 Javascript
浅谈jQuery中的checkbox问题
Aug 10 Javascript
footer定位页面底部(代码分享)
Mar 07 Javascript
详解vue项目构建与实战
Jun 27 Javascript
详解如何优雅地在React项目中使用Redux
Dec 28 Javascript
基于vue.js无缝滚动效果
Jan 25 Javascript
解决vue-cli@3.xx安装不成功的问题及搭建ts-vue项目
Feb 09 Javascript
详解钉钉小程序组件之自定义模态框(弹窗封装实现)
Mar 07 Javascript
node.js通过Sequelize 连接MySQL的方法
Dec 28 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 图像尺寸调整代码
2010/05/26 PHP
PHP性能优化 产生高度优化代码
2011/07/22 PHP
具有时效性的php加密解密函数代码
2013/06/19 PHP
php如何获取文件的扩展名
2015/10/28 PHP
PHP微信红包API接口
2015/12/05 PHP
jQuery hover 延时器实现代码
2011/03/12 Javascript
js判断上传文件的类型和大小示例代码
2013/10/18 Javascript
多种方法实现JS动态添加事件
2013/11/01 Javascript
node.js中Socket.IO的进阶使用技巧
2014/11/04 Javascript
javascript 对象数组根据对象object key的值排序
2015/03/09 Javascript
简介alert()与console.log()的不同
2015/08/26 Javascript
Vuejs第十三篇之组件——杂项
2016/09/09 Javascript
浅谈ajax请求不同页面的微信JSSDK问题
2018/02/26 Javascript
JS中用EL表达式获取上下文参数值的方法
2018/03/28 Javascript
通过vue-router懒加载解决首次加载时资源过多导致的速度缓慢问题
2018/04/08 Javascript
解决angularJS中input标签的ng-change事件无效问题
2018/09/13 Javascript
微信小程序时间选择插件使用详解
2018/12/28 Javascript
vue 地区选择器v-distpicker的常用功能
2019/07/23 Javascript
vue - vue.config.js中devServer配置方式
2019/10/30 Javascript
Js代码中的span拼接问题解决
2019/11/22 Javascript
electron 如何将任意资源打包的方法步骤
2020/04/16 Javascript
基于JS实现table导出Excel并保留样式
2020/05/19 Javascript
跟老齐学Python之一个免费的实验室
2014/09/14 Python
Python之自动获取公网IP的实例讲解
2017/10/01 Python
python实现列表中由数值查到索引的方法
2018/06/27 Python
Python socket聊天脚本代码实例
2020/01/02 Python
Python魔法方法 容器部方法详解
2020/01/02 Python
利用Storage Event实现页面间通信的示例代码
2018/07/26 HTML / CSS
Vans(范斯)德国官网:美国南加州的原创极限运动潮牌
2017/05/02 全球购物
韩国保养品、日本药妆购物网:小三美日
2018/12/30 全球购物
三星印度官网:Samsung印度
2019/08/03 全球购物
建筑工地门卫岗位职责
2014/04/30 职场文书
举起手来观后感
2015/06/09 职场文书
微信早安问候语
2015/11/10 职场文书
Django路由层如何获取正确的url
2021/07/15 Python
Ruby处理YAML和json数据
2022/04/18 Ruby