事件触发过程(事件流)

首先一个点击事件,事件会## 标题从最外层开始发生,到目标源,这个过程叫做事件捕获,事件再会从目标源最深的节点开始发生,一直向上传播,直到document对象,这个过程叫做事件冒泡,整个流程叫做事件流。

事件捕获
首先一个点击事件,事件会从最外层开始发生,直到最具体的元素,这个过程叫做事件捕获,addEventListener有三个参数,第三个参数为true的时候为事件捕获
通常我们使用 addEventListener 注册事件,该函数的第三个参数可以是布尔值,也可以是对象。对于布尔值 useCapture 参数来说,该参数默认值为 false ,useCapture 决定了注册的事件是捕获事件还是冒泡事件。对于对象参数来说,可以使用以下几个属性

capture:布尔值,和 useCapture 作用一样
once:布尔值,值为 true 表示该回调只会调用一次,调用后会移除监听
passive:布尔值,表示永远不会调用 preventDefault

事件冒泡:事件再会从最内层的元素开始发生,一直向上传播,直到document对象,这个过程叫做事件冒泡,onclick有三个参数,第三个参数为true的时候为事件冒泡
阻止事件冒泡:在W3C标准里调用e.stopPropagation(),而在IE下通过设window.event.cancelBubble=true来实现
阻止事件捕获:event.stopImmediatePropagation (),stopImmediatePropagation包含了stopPropagation的功能

注意: 事件触发一般来说会按照上面的顺序进行,但是也有特例,如果给一个 body 中的子节点同时注册冒泡和捕获事件,事件触发会按照注册的顺序执行。

// 以下会先打印冒泡然后是捕获
node.addEventListener('click',event => {console.log('冒泡')`在这里插入代码片`},false
)
node.addEventListener('click',event => {console.log('捕获 ')},true
)

事件委托(事件代理)

事件委托利用了事件冒泡的原理,就是指定一个事件处理程序,然后去管理某一类型的所有事件
一般来讲,会把一个或者一组元素的事件委托到它的父层或者更外层元素上,当事件响应到需要绑定的元素上时,会通过事件冒泡机制从而触发它的外层元素的绑定事件上,然后在外层元素上去执行函数。委托父级代为执行事件
事件委托的事件:click,mousedown,mouseup,keydown,keyup,keypress。比如有一个div包裹这五个点击事件,可以在div上设置点击事件,如果想要确认你点击是哪一个,可以用e.target去获取
绑定事件的方法:
(1)在dom中直接绑定,在DOM元素上绑定onclick、onmouseover、onmouseout onmousedown、onmouseup、ondblclick、onkeydown、onkeypress、onkeyup
(2)获取domdocument.getElementById
(3) 使用事件监听绑定 例如:addEventListener() 或 attachEvent() 来绑定事件监听函数
事件委托的局限性:
比如 focus、blur 之类的事件本身没有事件冒泡机制,所以无法委托;
mousemove、mouseout这样的事件,虽然有事件冒泡,但是只能不断通过位置去计算定位,对性能消耗高,因此也是不适合于事件委托的;
优点:
1.可以大量节省内存占用,减少事件注册。比如ul上代理所有li的click事件就很不错。
2.可以实现当新增子对象时,无需再对其进行事件绑定,对于动态内容部分尤为合适
缺点:
1.事件代理的常用应用应该仅限于上述需求,如果把所有事件都用事件代理,可能会出现事件误判。即本不该被触发的事件被绑定上了事件。

事件触发过程(事件流)相关推荐

  1. 点击事件触发mouseleave事件

    近日测试小姐姐给我提了一个bug,场景是一个显示航规的弹框,鼠标放上去,显示弹框,鼠标移开,弹框关闭.因为航规需要区分往返,所以我在弹框里面引入了element ui的tab组件,然后问题粗来了,测试 ...

  2. JavaScript 技巧篇-js增加延迟时间解决单击双击事件冲突,双击事件触发单击事件

    js 的单双击事件同时存在会有一个问题:双击事件会同时触发单击事件,两个事件存在冲突. 我们加一个延迟时间就能很好的解决这个问题. 原理: 当接收到第一个点击时,我们先把单击事件存储在这个是全局变量 ...

  3. 在C#中使用代理的方式触发事件 (委托和事件 ) (转)

    From:  http://www.cnblogs.com/gzhnan/articles/1859477.html 在C#中使用代理的方式触发事件 (委托和事件 ) 事件(event)是一个非常重要 ...

  4. [分布式控制浅述] (3)简单分布式事件触发控制

    [分布式控制浅述] (3)简单分布式事件触发控制 [分布式控制浅述] (3)简单分布式事件触发控制 1 前言 2 分布式事件触发控制 3 稳定性分析 [分布式控制浅述] (3)简单分布式事件触发控制 ...

  5. JavaScript事件与JQuery事件

    JavaScript JQuery <script> function display(){    alert("段落被点击了.");   } </script& ...

  6. Revit二次开发之双事件:空闲事件与DocumentChanged事件

    对以下文章所展示的代码进行了修改,当前展示的代码可直接复制使用. 由于本人初学,下列语言为个人理解,如有错误请指正. <引用1>中: 使用模态对话框,或者尽量保证事件在ExternalCo ...

  7. jqgrid 单元格绑定点击事件_自定义事件带参数的触发过程

    (接上讲) 这一讲我们先继续上一讲类模块代码的讲解: 6 Private Sub mySht_Change(ByVal Target As Range) RaiseEvent mySelectRanA ...

  8. 带你根据源码了解View的事件触发流程,主要讲解为什么子View返回true,ViewGroup就无法接收到事件的过程

    转载请标明出处!http://blog.csdn.net/sahadev_/article/details/23839039 ,当然一般也没人转载... 一直想彻底了解View的事件分发过程,在网上也 ...

  9. 通过c# 实现自定义属性改变触发自定义事件 ,理解自定义事件及其触发过程

    以下说明可解释自定义的事件的自定义触发过程: 直接上代码,内含说明(界面是两个文本框textbox1,textbox2,和一个button1,界面的Load事件,button的click事件) For ...

最新文章

  1. SAP 如何将无序列号的库存与序列号关联起来?
  2. 源、更新源时容易出现的问题解决方法
  3. 宝塔面板部署nuxt_MacOS下创建及部署vue.js项目(及Nuxt.js、PM2等相关流程)
  4. 区块链BaaS云服务(14)华大BGI区块链“碎片分布式存储“
  5. 网络钓鱼者钓到威胁情报公司的身上 黑客惨遭溯源
  6. 第一个Canvas实例-钟表
  7. matlab实现图像放大两倍,matlab图像处理基础知识0(双线性插值matlab实现--调整水平和垂直放大倍数)...
  8. vant实现下拉刷新和上拉加载_微信小程序 - 实现下拉刷新、上拉加载
  9. RobotFramework_4.SeleniumLibrary操作(二)
  10. 车架号查车辆型号_【菜鸟二手车大讲堂】第十一讲 经常提到的汽车车架号是什么?...
  11. hdu 2046 骨牌铺方格
  12. SQl 2000和SQL 2005之间的一些语法区别
  13. Redis 集群模式(Cluster)原理详解
  14. WPS(Word)中图注、域的使用基础
  15. (二十三)admin-boot项目之captcha验证码整合
  16. linux stat获取文件大小,Linux查看文件大小的几种方法示例 stat du ls awk (转)
  17. exe java环境未找到_Windows环境下安装jdk找不到javac.exe
  18. 当手机产业进入硬件能力过剩时代
  19. 利用 Heritrix 构建特定站点爬虫
  20. ffmpeg硬解码与软解码的压测对比

热门文章

  1. 个人简历模板html5
  2. OpenNI2的安装教程
  3. 老师怎么制作网上查分系统?
  4. 输入法-电脑输入法快速打出生僻字+运算
  5. 银河麒麟系统中的串口调试
  6. 【微信小程序常识】如何发布微信小程序体验版
  7. 发票查询,验证码无法刷新问题解决
  8. 11条职场潜规则助你爱上工作
  9. idea如何查看并去掉所有断点
  10. 查询MySQL数据库中所有表的结构