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 相关文章推荐
事件绑定之小测试  onclick &amp;&amp; addEventListener
Jul 31 Javascript
JS解决url传值出现中文乱码的另类办法
Apr 08 Javascript
AngularJS的内置过滤器详解
May 14 Javascript
跟我学习javascript的Date对象
Nov 19 Javascript
js 调用百度分享功能
Feb 27 Javascript
jQuery简易时光轴实现方法示例
Mar 13 Javascript
Web制作验证码功能实例代码
Jun 19 Javascript
解决Vue使用swiper动态加载数据,动态轮播数据显示白屏的问题
Sep 27 Javascript
在js代码拼接dom对象到页面上的模板总结
Oct 21 Javascript
es6中reduce的基本使用方法
Sep 10 Javascript
Ant Design Vue 添加区分中英文的长度校验功能
Jan 21 Javascript
JavaScript文档对象模型DOM
Nov 20 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
简单采集了yahoo的一些数据
2007/02/14 PHP
深入理解require与require_once与include以及include_once的区别
2013/06/05 PHP
分享下PHP register_globals 值为on与off的理解
2013/09/26 PHP
php发送短信验证码完成注册功能
2015/11/24 PHP
PHP PDOStatement::debugDumpParams讲解
2019/01/30 PHP
PHP isset empty函数相关面试题及解析
2020/12/11 PHP
json 定义
2008/06/10 Javascript
JS版的date函数(和PHP的date函数一样)
2014/05/12 Javascript
node.js中的path.dirname方法使用说明
2014/12/09 Javascript
简介JavaScript中setUTCSeconds()方法的使用
2015/06/12 Javascript
使用AngularJS创建单页应用的编程指引
2015/06/19 Javascript
jQuery插件 Jqplot图表实例
2016/06/18 Javascript
JS读写CSS样式的方法汇总
2016/08/16 Javascript
ionic组件ion-tabs选项卡切换效果实例
2016/08/27 Javascript
浅谈jQuery绑定事件会叠加的解决方法和心得总结
2016/10/26 Javascript
Web 开发中Ajax的Session 超时处理方法
2017/01/19 Javascript
原生js实现弹出层效果
2017/01/20 Javascript
日期时间范围选择插件:daterangepicker使用总结(必看篇)
2017/09/14 Javascript
JavaScript 保护变量不被随意修改的实现代码
2017/09/27 Javascript
element-ui 限制日期选择的方法(datepicker)
2018/05/16 Javascript
Vue 图片压缩并上传至服务器功能
2020/01/15 Javascript
用python实现百度翻译的示例代码
2018/03/09 Python
Python封装成可带参数的EXE安装包实例
2019/08/24 Python
python数据预处理 :样本分布不均的解决(过采样和欠采样)
2020/02/29 Python
python实现简易版学生成绩管理系统
2020/06/22 Python
Python 如何实现数据库表结构同步
2020/09/29 Python
欧舒丹比利时官网:L’OCCITANE比利时
2017/04/25 全球购物
广州足迹信息技术有限公司Java软件工程师试题
2014/02/15 面试题
外国语学院毕业生自荐信
2013/10/28 职场文书
毕业生求职信范文
2014/06/29 职场文书
学校学习雷锋活动总结
2014/07/03 职场文书
人事行政专员岗位职责
2014/07/23 职场文书
戒毒悔改检讨书
2014/09/21 职场文书
党的群众路线教育实践活动整改落实情况自查报告
2014/10/28 职场文书
新娘父亲婚礼致辞
2015/07/27 职场文书
《秋思》教学反思
2016/02/23 职场文书