javascript 中事件冒泡和事件捕获机制的详解


Posted in Javascript onSeptember 01, 2017

javascript 中事件冒泡和事件捕获机制的详解

二者作用:描述事件触发时序问题

事件捕获:从document到触发事件的那个节点,即自上而下的去触发事件---由外到内

事件冒泡:自下而上的去触发事件---由内到外

绑定事件方法的第三个参数,就是控制事件触发顺序是否为事件捕获

true,事件捕获;false,事件冒泡

一般默认false,即事件冒泡

Jquery的e.stopPropagation会阻止冒泡,意思就是到DOM为止,祖先级的事件就不要触发了 

下面是我尝试的例子:

<!DOCTYPE html> 
<html lang="en"> 
<head> 
  <meta charset="UTF-8"> 
  <title>事件冒泡与事件捕获</title> 
  <script> 
    window.onload = function () { 
      document.getElementById("parent").addEventListener("click",function(e){ 
        alert("parent事件被触发,"+this.id); 
      },true) 
      document.getElementById("child").addEventListener("click",function(e){ 
        alert("child事件被触发,"+this.id) 
      },true) 
    } 
 
  </script> 
</head> 
<body> 
<div id="parent"> 
  parent事件 
  <div id="child" class="child"> 
  child事件 
  </div> 
</div> 
</body> 
</html>

 例子里我加了第三个true,是事件捕获。

如果不加则是默认的事件冒泡,这时候事件触发时序就是自内向外

以上就是javascript 中事件冒泡和事件捕获机制的详解,如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

Javascript 相关文章推荐
JavaScript语法着色引擎(demo及打包文件下载)
Jun 13 Javascript
扩展Jquery插件处理mouseover时内部有子元素时发生样式闪烁
Dec 08 Javascript
jQuery Migrate 1.1.0 Released 注意事项
Jun 14 Javascript
Javascript学习笔记之函数篇(四):arguments 对象
Nov 23 Javascript
javascript+canvas制作九宫格小程序
Dec 28 Javascript
JavaScript实现下拉列表框数据增加、删除、上下排序的方法
Aug 11 Javascript
vue组件如何被其他项目引用
Apr 13 Javascript
JQuery 获取Dom元素的实例讲解
Jul 08 jQuery
使用selenium抓取淘宝的商品信息实例
Feb 06 Javascript
Flutter实现仿微信底部菜单栏功能
Sep 18 Javascript
javascript实现多边形碰撞检测
Oct 24 Javascript
VUE-ElementUI 自定义Loading图操作
Nov 11 Javascript
Vue的Class与Style绑定的方法
Sep 01 #Javascript
Angular中封装fancyBox(图片预览)遇到问题小结
Sep 01 #Javascript
BootStrap模态框和select2合用时input无法获取焦点的解决方法
Sep 01 #Javascript
Angularjs实现上传图片预览功能
Sep 01 #Javascript
JavaScript中使用参数个数实现重载功能
Sep 01 #Javascript
bootstrap-table实现服务器分页的示例 (spring 后台)
Sep 01 #Javascript
jQuery EasyUI结合zTree树形结构制作web页面
Sep 01 #jQuery
You might like
PHP中file_get_contents高?用法实例
2014/09/24 PHP
PHP使用PDO调用mssql存储过程的方法示例
2017/10/07 PHP
ExtJs使用IFrame的实现代码
2010/03/24 Javascript
jquery.cvtooltip.js 基于jquery的气泡提示插件
2010/11/19 Javascript
跨域传值即主页面与iframe之间互相传值
2013/12/09 Javascript
利用javascript实现全部删或清空所选的操作
2014/05/27 Javascript
Javascript+CSS实现影像卷帘效果思路及代码
2014/10/20 Javascript
js中常用的Tab切换效果(推荐)
2016/08/30 Javascript
详解利用jsx写vue组件的方法示例
2017/07/17 Javascript
浅谈vue项目打包优化策略
2018/09/29 Javascript
微信小程序实现的canvas合成图片功能示例
2019/05/03 Javascript
vue 更改连接后台的api示例
2019/11/11 Javascript
JS代码触发事件代码实例
2020/01/02 Javascript
python模拟新浪微博登陆功能(新浪微博爬虫)
2013/12/24 Python
深入理解python try异常处理机制
2016/06/01 Python
windows中安装Python3.8.0的实现方法
2019/11/19 Python
centos7中安装python3.6.4的教程
2019/12/11 Python
python如何使用socketserver模块实现并发聊天
2019/12/14 Python
Python使用多进程运行含有任意个参数的函数
2020/05/02 Python
Django windows使用Apache实现部署流程解析
2020/10/12 Python
PyCharm最新激活码(2020/10/27全网最新)
2020/10/27 Python
HTML5对手机页面长按会粘贴复制禁用的解决方法
2016/07/19 HTML / CSS
荷兰优雅女装网上商店:Heine
2016/11/14 全球购物
微软台湾官方网站:Microsoft台湾
2018/08/15 全球购物
意大利咖啡、浓缩咖啡和浓缩咖啡机:illy caffe
2019/03/20 全球购物
20岁生日感言
2014/01/13 职场文书
工厂总经理岗位职责
2014/02/07 职场文书
冬季安全检查方案
2014/05/23 职场文书
《爱的教育》读书心得
2014/11/08 职场文书
2014年平安建设工作总结
2014/11/19 职场文书
志愿者事迹材料
2014/12/26 职场文书
工作时间证明
2015/06/15 职场文书
2015双创工作总结
2015/07/24 职场文书
MySQL 使用索引扫描进行排序
2021/06/20 MySQL
Redis+AOP+自定义注解实现限流
2022/06/28 Redis
CSS 实现磨砂玻璃(毛玻璃)效果样式
2023/05/21 HTML / CSS