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 相关文章推荐
Google Map API更新实现用户自定义标注坐标
Jul 29 Javascript
javascript 隐藏/显示指定的区域附HTML元素【legend】用法
Mar 05 Javascript
jquery tab标签页的制作
May 10 Javascript
JavaScript日历实现代码
Sep 12 Javascript
JavaScript bold方法入门实例(把指定文字显示为粗体)
Oct 17 Javascript
浅谈Javascript变量作用域问题
Dec 16 Javascript
jQuery实现商品活动倒计时
Oct 16 Javascript
初步了解javascript面向对象
Nov 09 Javascript
实现高性能JavaScript之执行与加载
Jan 30 Javascript
jQuery简单实现提交数据出现loading进度条的方法
Mar 29 Javascript
JavaScript中闭包的写法和作用详解
Jun 29 Javascript
vue里面使用mui的弹出日期选择插件实例
Sep 16 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
德劲1102收音机的打理维修案例
2021/03/02 无线电
PHP MVC模式在网站架构中的实现分析
2010/03/04 PHP
php采用curl实现伪造IP来源的方法
2014/11/21 PHP
PHP版本如何选择?应该使用哪个版本?
2015/05/13 PHP
PHP实现事件机制的方法
2015/07/10 PHP
php+Ajax处理xml与json格式数据的方法示例
2019/03/04 PHP
jquery ajax 登录验证实现代码
2009/09/23 Javascript
分享十五个最佳jQuery 幻灯插件和教程
2010/03/27 Javascript
jQuery实现图片信息的浮动显示实例代码
2013/08/28 Javascript
jQuery对象和DOM对象之间相互转换的方法介绍
2015/02/28 Javascript
Js+Ajax,Get和Post在使用上的区别小结
2016/06/08 Javascript
Javascript实现图片不间断滚动的代码
2016/06/22 Javascript
浅谈JS继承_寄生式继承 &amp; 寄生组合式继承
2016/08/16 Javascript
Asp.Net之JS生成分页条的方法
2016/11/23 Javascript
基于Node.js + WebSocket打造即时聊天程序嗨聊
2016/11/29 Javascript
利用HTML5+Socket.io实现摇一摇控制PC端歌曲切换
2017/01/13 Javascript
BootStrap表单验证实例代码
2017/01/13 Javascript
Bootstrap超大屏幕的实现代码
2017/03/22 Javascript
socket io与vue-cli的结合使用的示例代码
2018/11/01 Javascript
详解vue父子组件关于模态框状态的绑定方案
2019/06/05 Javascript
python+django快速实现文件上传
2016/10/24 Python
python实现石头剪刀布程序
2021/01/20 Python
Python Matplotlib实现三维数据的散点图绘制
2019/03/19 Python
Python调用百度根据经纬度查询地址的示例代码
2019/07/07 Python
python路径的写法及目录的获取方式
2019/12/26 Python
Python抓包并解析json爬虫的完整实例代码
2020/11/03 Python
CSS3实现淘宝留白的方法
2020/06/05 HTML / CSS
酒店办公室文员岗位职责
2013/12/18 职场文书
技校毕业生自荐信范文
2014/03/07 职场文书
终止合同协议书
2014/04/17 职场文书
党务公开方案
2014/05/06 职场文书
质量承诺书怎么写
2014/05/24 职场文书
排查整治工作方案
2014/06/09 职场文书
工作失误检讨书(3篇)
2014/10/11 职场文书
《分数乘法》教学反思
2016/02/24 职场文书
创业者如何撰写出一份打动投资人的商业计划书?
2019/07/02 职场文书