码迷,mamicode.com
首页 > 其他好文 > 详细

Event flow(事件流)

时间:2018-12-06 14:36:53      阅读:286      评论:0      收藏:0      [点我收藏+]

标签:事件流   目标   event   view   click   元素   不可   btn   定义   

例子:
<div> <button id="btn">Click Me!</button> </div>

对于上面例子,如果想知道点击后例子的运行顺序,此时就与Event flow(事件流动)相关了。

事件流动

DOM事件不单单只会在一个Element上触发,它还会流向其他Element。事件的流动通常会经历这么三个阶段:

捕获阶段 -> 目标阶段 -> 冒泡阶段



捕获阶段(capture phase)

定义:事件对象在事件目标的祖先中上到下顺向传播,从最顶层的defaultView到事件目标的(直系)父元素。

 

捕获阶段发生在整个事件流动的开始。在这阶段里事件会从父(主干)到子(分支)由上往下传播,被元素一层层地捕获。
文章开头的例子里面,捕获阶段的click事件会依次在document、body、div上触发:

 

目标阶段(target phase)

定义:事件对象到达事件目标。

 

就如例子中,事件在button上触发。

如果事件是不可冒泡的,那整个事件流动会到此为止,不会发生下面的冒泡阶段。

 

冒泡阶段(bubble phase)

定义:事件对象会在事件目标的祖先元素里反向传播,由开始的父元素到最后的defaultView(document)。

 

冒泡阶段发生在最后,这也是我们最为熟悉的一个阶段。在这阶段里事件会从子(分支)到父(主干)逆向传播,看起来像是一个水里的泡泡往上冒。
例子里面,冒泡阶段的click事件会依次在div、body、document上触发:



Event flow(事件流)

标签:事件流   目标   event   view   click   元素   不可   btn   定义   

原文地址:https://www.cnblogs.com/shjnb/p/10075941.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!