DOM 事件与事件委托

本文写于 2020 年 5 月 28 日

先思考一个问题:我们如何给一百个 button 添加点击事件?

遍历?

那岂不是要添加一百个监听器?

这就需要事件委托了。

其实这根本不是一个很难的概念,看下去,本文并不长。

1. 点击事件

现在我们拥有三个元素,他们嵌套成为爷爷、爸爸、儿子:

<div class='grandpa'>
<div class='father'>
<div class='son'></div>
</div>
</div>

然后分别给他们仨添加不同的三个事件监听。

因为事件冒泡,我们能知道他们都会执行,并且会按照一定顺序执行。

但是不同浏览器的顺序是不一样的

IE 认为应该调用 .son 的事件,网景认为应该调用 .grandpa

后来 2002 年,W3C 发布了标准:

  • 先按照从外向内——事件捕获
  • 在按照从内向外——事件冒泡

整个过程就是——有监听函数就调用,没有就跳过。

开发者可以自己选择把最外层的事件,放在捕获阶段还是冒泡阶段。

如何选择呢?其实就是我们最熟悉的addEventListener

我们经常会用它去绑定事件,我们一般都只会传入两个参数。

可实际上这个函数有 3 个参数

我们可以在第三个参数,放置一个布尔值,例如:xxx.addEventListener('click', fn, bool)

如果是true,则是捕获方式(从外向内);如果不写,或者是falsy值,则是冒泡(从内向外)

顺序问题

上面说了,先捕获后冒泡。

那我同时给一个元素,先挂一个冒泡,再挂一个捕获——谁先触发?

谁先写,谁先触发,因为他们是同级的

可以取消吗?

捕获不可以取消,但是冒泡可以取消。(有些事件不能取消,比如滚动事件)

e.stopPropagation()中断冒泡。

2. 事件委托

回到我们刚开始的问题:我们如何给一百个 button 添加点击事件?

肯定不是遍历。

我们可以直接给父元素添加事件,例如:

father.addEventListener('click', e => {
console.log(e.target)
console.log(e.currentTarget)
})

这里看到,我们传入了一个 e,这个 e 可以尝试打印出来,就会发现其实是MouseEvent

这是一个对象,里面有各种各样的数据,比如我们需要的target

target就是用户所点击的元素!

也就是说如果 father 有 10 个孩子,从 child1 一直到 child10,我们点谁,这个 target 就是谁

e.currentTarget呢,和e.target是有区别的!

简单来说呢 target被操作的元素currentTarget被监听的元素

在这个例子中,currentTarget 恒为 father,target 则会随着点击发生改变。

最后说一下,JS 其实是不支持事件的!支持事件的是浏览器,addEventListener 是浏览器的 DOM 提供的。

(完)

DOM 事件与事件委托的更多相关文章

  1. DOM事件机制(事件捕获和事件冒泡和事件委托)

    内容: 1.事件复习 2.事件冒泡与事件捕获 3.事件委托 1.事件复习 (1)事件 事件是用来处理响应的一个机制,这个响应可以来自于用户(点击, 鼠标移动, 滚动), 也可以来自于浏览器 下面的链接 ...

  2. DOM 事件机制&事件委托

    一.事件机制 事件是在编程时系统内发生的动作或者发生的事情,系统会在事件出现的时候触发某种信号并且会提供一个自动加载某种动作的机制(来自MDN).每个事件都有事件处理器(有时也叫事件监听器),也就是触 ...

  3. HTML 事件(三) 事件流与事件委托

    本篇主要介绍HTML DOM中的事件流和事件委托. 其他事件文章 1. HTML 事件(一) 事件的介绍 2. HTML 事件(二) 事件的注册与注销 3. HTML 事件(三) 事件流与事件委托 4 ...

  4. jQuery事件绑定和委托

    可以用多种方法实现,on()  . bind()  . live()  . delegate() ,还有one(). 有时我们可能会像下面这样绑定一个事件: $("#div1"). ...

  5. JS中事件代理与委托

    在javasript中delegate这个词经常出现,看字面的意思,代理.委托.那么它究竟在什么样的情况下使用?它的原理又是什么?在各种框架中,也经常能看到delegate相关的接口.这些接口又有什么 ...

  6. JQ 为未来元素添加事件处理器—事件委托

    随着DOM结构的复杂化和Ajax等动态脚本技术的运用,有了较多的动态添加进来的元素,直接用JQ添加click事件会发现新添加进来的元素并不能直接选取到,在这里就需要用到事件委托方法,JQ为事件委托提供 ...

  7. [JavaScript] JavaScript事件注册,事件委托,冒泡,捕获,事件流

    面试题 event 事件 事件委托是什么? 如何阻止事件冒泡,阻止默认事件呢? Javascript 的事件流模型都有什么? 事件绑定和普通事件有什么区别? Event 对象 Event 对象,当事件 ...

  8. JavaScript事件代理和委托

    在javasript中,代理.委托经常出现. 那么它究竟在什么样的情况下使用?它的原理又是什么? 这里介绍一下javascript delegate的用法和原理,以及Dojo,jQuery等框架中de ...

  9. 理解js事件冒泡事件委托事件捕获

    js事件冒泡 javascript的事件传播过程中,当事件在一个元素上出发之后,事件会逐级传播给先辈元素,直到document为止,有的浏览器可能到window为止,这就是事件冒泡现象. <di ...

随机推荐

  1. springboot使用redis实现发布与订阅

    配置redis连接地址 # Redis服务器地址 spring.redis.host=youxiu326.xin # Redis服务器连接端口 spring.redis.port=6379 # Red ...

  2. 【译】客户端存储(Client-Side Storage)

    本文转载自:众成翻译译者:文蔺链接:http://www.zcfy.cc/article/660原文:http://www.html5rocks.com/en/tutorials/offline/st ...

  3. 首次写iPad布局感想(H5)

    一直做前端工作,却从来没有开发过平板的项目,想来也是有遗憾的,孰知,新公司的第二个项目就是要适配平板,刚开始是懵的,对于兼容,感觉是自己的短板,但庆幸的是这一版只需要兼容iOS系统就可以. 那我现在就 ...

  4. H5 视频播放解决方案

    前两天,美团推出的杨洋H5火爆朋友圈.里面主要的是多段视频播放.暂停.听起来很简单,但是由于腾讯白名单限制,在微信浏览器,qq浏览器,会自动将video标签中非腾讯域名的视频 ,自动全屏,结尾追加视频 ...

  5. spark-shell报错java.lang.IllegalArgumentException: java.net.UnknownHostException: namenode

    在使用spark on yarn启动spark-shell时,发现报错: 是说找不到主机名为namenode的主机,那么应该是配置文件出错了. 经过检查,发现是spark-defaults.conf文 ...

  6. javascript,如何实现数据绑定

    在三大框架 抢占前端开发技术领域的时代,基本每个框架都是实现了数据绑定, 今天我们来解密一下数据绑定的原理, 原理关乎一个很关键的东西,Object.prototype.__defineSetter和 ...

  7. java集合(arraylist详解)

    一.ArrayList概述 ArrayList是实现List接口的动态数组,所谓动态就是它的大小是可变的.实现了所有可选列表操作,并允许包括 null 在内的所有元素.除了实现 List 接口外,此类 ...

  8. zabbix使用自带模板监控MySQL

    监控mysql不能直接使用zabbix自带模板,还需要到被监控的mysql客户端做配置. 1.在zabbix   web配置步骤如下图: 2.配置完之后去看mysql主机监控项的时候看到mysql的监 ...

  9. findmnt、lsblk、mount 命令查看磁盘、目录挂载、挂载点以及文件系统格式等情况

    findmnt 展示出了目标挂载点( TARGET ).源设备( SOURCE ).文件系统类型( FSTYPE )以及相关的挂载选项( OPTIONS ),例如文件系统是否是可读可写或者只读的.根( ...

  10. Servlet 3.1学习笔记

    Servlet 3.1学习笔记 参考文档 Servlet 3.1标准 什么是 Servlet ? Servlet 是基于 Java 平台的 Web 组件,由一个容器管理,能够生成动态内容. 什么是 S ...