js事件委托总结

栏目: JavaScript · 发布时间: 6年前

内容简介:补充一直没写的总结:eyes:当简单回顾咯DOM事件流包括三个阶段:事件捕获阶段,处于目标阶段与事件冒泡阶段

补充一直没写的总结:eyes:当简单回顾咯

DOM事件流

DOM事件流包括三个阶段:事件捕获阶段,处于目标阶段与事件冒泡阶段

js事件委托总结

即比如点击td元素时,由外至内层会经历捕获阶段,目标阶段,冒泡阶段三个阶段,相应地会触发路径元素上的事件

此外,addEventListener(type, listener[, useCapture])函数默认设置在冒泡阶段,路径元素的事件才会触发,此参数为可选值,默认值为false,示例代码一并标出

示例代码:

<div id="grandFather" style="width: 700px;height: 700px; background-color: red">
        <p>grandFather</p>
        <div id="father1" style="width: 300px; height: 300px; background-color: pink">
            <p>father1</p>
            <div id="son1" style="width: 100px; height: 100px; background-color: yellow">
                <p>son1</p>
            </div>
        </div>
        <div id="father2" style="width: 300px;height: 300px; background-color: green">
            <p>father2</p>
        </div>
    </div>
    <script type="text/javascript">
        let grandFather = document.getElementById('grandFather'),
            father1 = document.getElementById('father1'),
            son1 = document.getElementById('son1'),
            father2 = document.getElementById('father2');
        
        grandFather.addEventListener('click', function(event){console.log('I am grandFather')},true);
        father1.addEventListener('click', function(event){console.log('I am father1')},false);
        son1.addEventListener('click', function(event){console.log('I am son1')},false);
        father2.addEventListener('click', function(event){console.log('I am father2')},false);
    </script>

点击son1 div时,会冒泡触发father1与grandFather事件

js事件委托总结

若将grandFather的use capture参数改为true,则会相应改变执行顺序

grandFather.addEventListener('click', function(event){console.log('I am grandFather')},true);

js事件委托总结

以上是事件流的简单总结,下面事件委托是对事件冒泡的应用

事件委托

如果在需要有多个DOM事件需要监听的情况下(比如几百条微博点击事件注册),给每一个DOM都绑定监听函数,对性能会有极大的影响,因此,有一解决方案为事件委托。

事件委托利用了 事件冒泡event.target

event.currentTarget与event.target

currentTarget:表示此事件绑定的元素

target:通俗理解为表示触发一系列事件的源头

我们再次修改grandFather的监听函数

grandFather.addEventListener('click', function(event){
    console.log('I am grandFather!!!')
    console.log('currentTarget:');
    console.log(event.currentTarget); 
    console.log('target:');
    console.log(event.target);},false); //这里已改回false

再次点击son1,进入grandFather的监听函数后显示如下

js事件委托总结

事件委托具体步骤

了解冒泡与target后,不难可以想到若是在几百个dom监听之中,只需把监听函数绑定在父容器上即可,这里依旧拿这个简单的例子修改,我们要做的是点击某个div便显示打印'I am xxx'

首先,给div都绑定自定义的 data-name 属性

<!-- 没有给p元素设置data-name,点击p元素时会显示data-name为null -->
    <div id="grandFather" data-name="grandFather" style="width: 700px;height: 700px; background-color: red">
        <p>grandFather</p>
        <div id="father1" data-name="father1" style="width: 300px; height: 300px; background-color: pink">
            <p>father1</p>
            <div id="son1" data-name="son1" style="width: 100px; height: 100px; background-color: yellow">
                <p>son1</p>
            </div>
        </div>
        <div id="father2" data-name="father2" style="width: 300px;height: 300px; background-color: green">
            <p>father2</p>
        </div>
    </div>

接着改写grandFather的监听函数

grandFather.addEventListener('click', function(event){
            console.log('I am ' + event.target.getAttribute('data-name'));
        },false);
        //这些可以注释掉了!
        // father1.addEventListener('click', function(event){console.log('I am father1')},false);
        // son1.addEventListener('click', function(event){console.log('I am son1')},false);
        // father2.addEventListener('click', function(event){console.log('I am father2')},false);

这样子就是一个简单的委托,更多的应用可以结合switch等等

参考资料


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

第三次浪潮

第三次浪潮

[美]阿尔文·托夫勒 / 黄明坚 / 中信出版集团 / 2018-7 / 79.00元

《第三次浪潮》是美国著名未来学家阿尔文•托夫勒的代表作之一。1980年出版之际,随即引起全球热评,堪称中国改革开放的指南。本书阐述了由科学技术发展引起的社会各方面的变化与趋势。托夫勒认为,人类迄今为止已经经历了两次浪潮文明的洗礼:第一次是农业革命,人类就此从原始渔猎时代进入以农业为基础的文明社会,并历经千年,直到工业革命的到来。随后,人类社会历时300年摧毁了落后的第一次浪潮文明,并在“二战”后1......一起来看看 《第三次浪潮》 这本书的介绍吧!

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

Base64 编码/解码
Base64 编码/解码

Base64 编码/解码

MD5 加密
MD5 加密

MD5 加密工具