JS之event flow

DOM事件流

1.定义:

DOM(文档对象模型)结构是一个树型结构,当一个HTML元素产生一个事件时,该事件会在元素节点与根结点之间的路径传播,路径所经过的结点都会收到该事件,这个传播过程可称为DOM事件流。DOM事件流最独特的性质是,文本节点也触发事件(在IE中不会),当鼠标单击“单击此文本”文本时会触发click事件,该事件的捕获阶段最先开始,从Document节点开始逐渐向下传播,直到“单击此文本”文本节点,事件进入目标阶段,在目标阶段结束之后,事件由“单击此文本”文本节点开始事件的冒泡阶段,直到Document节点为止。

2.两种事件流:

冒泡型事件流:事件的传播是从最特定事件目标到最不特定的事件目标。即从DOM树的叶子到根。

捕获型事件流:事件的传播的英文从最不特定事件目标到最特定的事件目标。即从DOM树的根到叶子。

 1 <模板>
2 <div id =“div1”style =“width:200px; height:200px;” V-上:click.capture = “迎接( '1',$事件)”>
3 <div id =“div2”style =“width:150px; height:150px;” V-上:click.capture = “迎接( '2',$事件)”>
4 <div id =“div3”style =“width:100px; height:100px;” V-上:click.capture = “迎接( '3',$事件)”> 3 </ DIV>
5 </ DIV>
6 </ DIV>
7 </模板>
8
9 <SCRIPT>
10 从“vue”导入Vue;
11 export default {
12 名字:'你好',
13 data(){
14 返回{
15 名称:'Vue.js'
16 }
17 },
18 方法:{
19 greet:function(msg,e){
20 执行console.log(味精)
21 }
22 }
23 }
24 </ SCRIPT>
25
26 <! - 添加“scoped”属性以仅将CSS限制为此组件 - >
27 <style scoped>
28 DIV {
29 border:1px#333 solid
30 }
31 </样式>

输出:

使用DOM事件流在DOM树中调度的事件的图形表示

事件对象被分派到事件目标。但是在发送开始之前,必须首先确定事件对象的传播路径传播路径是的有序列表的当前事件的目标,通过该事件传递。该传播路径反映了文档的分层树结构。列表中的最后一项是事件目标,列表中的前面项目称为目标的祖先,前面的项目作为目标的父项。一旦确定了传播路径,事件对象就会经过一个或多个事件阶段。有三个事件阶段:捕获阶段目标阶段泡沫阶段。事件对象完成这些阶段,如下所述。如果不支持某个阶段,或者事件对象的传播已停止,则将跳过该阶段。例如,如果bubbles属性设置为false,则将跳过气泡阶段,如果stopPropagation()在分派之前调用,则将跳过所有阶段。

(1)捕获阶段:事件对象通过目标的祖先从传播窗口到目标的父,即事件从目标节点自上而下向Document节点传播的阶段。

(2)目标阶段:本次活动对象到达事件对象的事件的目标。如果事件类型指示事件未冒泡,则事件对象将在此阶段完成后暂停,即事件从目标节点自上而下向Document节点传播的阶段。

(3)冒泡阶段:事件对象通过目标的祖先中传播以相反的顺序,开始与目标的父和与所述结束窗口,即事件从目标节点自上而下向Document节点传播的阶段。

参数描述event必需。描述事件名称的字符串。

注意: 不要使用 "on" 前缀。例如,使用 "click" 来取代 "onclick"。

提示: 所有 HTML DOM 事件,可以查看我们完整的 HTML DOM Event 对象参考手册function必需。描述了事件触发后执行的函数。

当事件触发时,事件对象会作为第一个参数传入函数。 事件对象的类型取决于特定的事件。例如, "click" 事件属于 MouseEvent(鼠标事件) 对象。useCapture可选。布尔值,指定事件是否 在捕获或冒泡阶段执行。

可能值:

  • true - 事件句柄在捕获阶段执行
  • false- 默认。事件句柄在冒泡阶段执行

DOCTYPE html>
2 <head>
3 <meta charset="UTF-8">
4 <title>DOM事件流</title>
5 </head>
6 <body>
7 <div id="div1">
8 <button id="btn">按钮</button>
9 </div>
10 <script>
11 var btn = document.getElementById("btn");
12 var div1 = document.getElementById("div1");
13
14 //事件目标
15 btn.onclick = function(){
16 console.debug("目标1.Click btn");
17 }
18 btn.addEventListener("click",function(){
19 console.debug("目标2.Click btn");
20 },true);
21
22 //事件冒泡
23 div1.onclick = function(){
24 console.debug("冒泡1.Click div1");
25 }
26 document.body.onclick = function(){
27 console.debug("冒泡2.Click Body");
28 }
29 document.onclick = function(){
30 console.debug("冒泡3.Click document");
31 }
32 window.onclick = function(){
33 console.debug("冒泡4.Click window");
34 }
35
36 //事件捕获
37 window.addEventListener("click",function(){
38 console.debug("捕获4.Click window");
39 },true);
40 document.addEventListener("click",function(){
41 console.debug("捕获3.Click document");
42 },true);
43 document.body.addEventListener("click",function(){
44 console.debug("捕获2.Click body");
45 },true);
46 div1.addEventListener("click",function(){
47 console.debug("捕获1.Click div1");
48 },true);
49
50 </script>
51 </body>
52 </html>

1 document.body.addEventListener("click",function(){
2 console.debug("捕获2.Click body");
3 },true);

addEventListener用于注册事件的处理器,当添加了第三个参数为true时,代表了在捕捉阶段接受后代元素的事件。

点击button按钮后,结果如下

 1 event.html:38 捕获4.Click window
2 event.html:41 捕获3.Click document
3 event.html:44 捕获2.Click body
4 event.html:47 捕获1.Click div1
5 event.html:16 目标1.Click btn
6 event.html:19 目标2.Click btn
7 event.html:24 冒泡1.Click div1
8 event.html:27 冒泡2.Click Body
9 event.html:30 冒泡3.Click document
10 event.html:33 冒泡4.Click window

这个方法就是:stopPropagation() 对button的click事件做一些改造。

event flow的更多相关文章

  1. 关于 javascript event flow 的一个bug

    [1]描述了firefox,safari 有一个bug和DOM 3 规范不一致:在event.currentTarget等于event.target的时候(即event flow处于target ph ...

  2. Javascript——浅谈 Event Flow

    1.Javascript Events : Event Bubbling(事件冒泡) 如果事件从最特定的元素开始,则事件流中的一个阶段称为事件冒泡(DOM中可能最深的节点)然后向上流向最不特定的节点( ...

  3. javaScript高级教程(五) Event Flow

    1.两个阶段三个模型:Netscape支持事件捕获,IE支持事件冒泡,w3c是先捕获后冒泡 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 S ...

  4. SAP事件 Event Flow(转载)

    1 报表过程事件 报表过程事件是在报表运行过程中由系统自动控制,按照一定次序被触发的事件,其目的是从数据库中选择数据并整理,准备进行列表输出.这些事件从报表程序启动开始就被系统顺序触发,现分述如下: ...

  5. JS之event flow

    DOM事件流 1.定义: DOM(文档对象模型)结构是一个树型结构,当一个HTML元素产生一个事件时,该事件会在元素节点与根结点之间的路径传播,路径所经过的结点都会收到该事件,这个传播过程可称为DOM ...

  6. DOM: EVENT FLOW

    捕获阶段(capture phase) 捕获阶段的定义如下(w3c):The event object propagate through the target's ancestors from th ...

  7. [DOM Event Learning] Section 4 事件分发和DOM事件流

    [DOM Event Learning] Section 4 事件分发和DOM事件流 事件分发机制: event dispatch mechanism. 事件流(event flow)描述了事件对象在 ...

  8. 关于js中return false、event.preventDefault()和event.stopPropagation()

    在平时项目中,如果遇到需要阻止浏览器默认行为,大家经常会用return false;和event.preventDefault()来阻止,但对它俩的区别还是有些一知半解,于是看了文档,查了些资料,在此 ...

  9. What is event bubbling and capturing?

    What is event bubbling and capturing? 答案1 Event bubbling and capturing are two ways of event propaga ...

随机推荐

  1. excel VBA动态链接数据库

    最近车间制造部有需求,需要通过excel填写的ID获取数据库中的某个取值.研究了一下VBA,简要记录一下代码,仅供参考. Function GETPMAX(SID As String) As Stri ...

  2. Vue/Egg大型项目开发(一)搭建项目

    项目Github地址:前端(https://github.com/14glwu/stuer)后端(https://github.com/14glwu/stuer-server) 项目线上预览:http ...

  3. bzoj 1283 序列 - 费用流

    题目传送门 传送门 题目大意 给定一个长度为$n$的序列,要求选出一些数使得原序列中每$m$个连续的数中不超过$K$个被选走.问最大的可能的和. 感觉建图好妙啊.. 考虑把问题转化成选$m$次数,每次 ...

  4. Android中的广播基本实现及回调方法的理解

    在Android中broadcast这一节的内容其实不算多主要是牵扯到一个broadcastreceiver类,这个类是一个抽象类,下面有一个抽象方法onreceiver(),可以再我们收到网络状态变 ...

  5. PO、POJO、BO、DTO、VO之间的区别(转)

    PO:persistent object持久对象 1 .有时也被称为Data对象,对应数据库中的entity,可以简单认为一个PO对应数据库中的一条记录. 2 .在hibernate持久化框架中与in ...

  6. 【Java基础】浅谈常见设计模式

    Num1:单例模式 基本概念:保证一个类仅有一个实例,并提供一个访问它的全局访问点. 常见写法: 懒汉式 public class Singleton { /* 持有私有静态实例,防止被引用,此处赋值 ...

  7. Visual Studio 2017 和 Visual Assist X 番茄助手的安装教程

    声明:本文所提供的所有软件均来自于互联网,仅供个人研究和学习使用,请勿用于商业用途,下载后请于24小时内删除,请支持正版! 一.Visual Studio 2017的安装教程 Visual Studi ...

  8. Linux根目录下各个目录的用途及含义

    Linux根目录下各个目录的用途及含义 Linux ./bin 重要的二进制 (binary) 应用程序,包含二进制文件,系统的所有用户使用的命令都在这个目录下. ./boot 启动 (boot) 配 ...

  9. IOS高级开发之多线程(四)NSOperation

    1.什么是NSOperation,NSOperationQueue? NSOperation是一个抽象的基类,表示一个独立的计算单元,可以为子类提供有用且线程安全的建立状态,优先级,依赖和取消等操作. ...

  10. PHP工程师必备知识整理

    一.http/https协议,tcp/ip协议,websocket,session,cookie 二.php:oop,thinkphp5,laravel 三.mysql.memcache.redis ...