zoukankan      html  css  js  c++  java
  • 0173 事件委托:原理、作用

    事件冒泡本身的特性,会带来的坏处,也会带来的好处。

    1.3.8.1 什么是事件委托

    事件委托:也称为事件代理,在 jQuery 里面称为事件委派。

    把事情委托给别人,代为处理。
    

    说白了就是,不给子元素注册事件,给父元素注册事件,把处理代码在父元素的事件中执行。


    生活中的代理:


    js事件中的代理:


    1.3.8.2 事件委托的原理

    ​ 给父元素注册事件,利用事件冒泡,当子元素的事件触发,会冒泡到父元素,然后去控制相应的子元素【利用事件冒泡影响每一个子节点】。


    1.3.8.3 事件委托的作用

    • 我们只操作了一次 DOM ,提高了程序的性能。

    • 动态新创建的子元素,也拥有事件。

        <ul>
            <li>知否知否,点我应有弹框在手1111!</li>
            <li>知否知否,点我应有弹框在手2222!</li>
            <li>知否知否,点我应有弹框在手3333!</li>
            <li>知否知否,点我应有弹框在手4444!
    			<!-- 加的3行代码。【经试验,孙子级的元素也一样起作用】 -->
                <div>aaa</div>
                <div>bbb</div>
                <div>ccc</div>
            </li>
            <li>知否知否,点我应有弹框在手5555!</li>
        </ul>
        <script>
            // 事件委托的核心原理:给父节点添加侦听器, 利用事件冒泡影响每一个子节点
            var ul = document.querySelector('ul');
    
            // 点击的是li,li冒泡,往上传给ul,ul也绑定了点击事件,于是执行相应代码。
            ul.addEventListener('click', function(e) {
                // alert('知否知否,点我应有弹框在手!');
                // e.target 这个可以得到我们点击的对象
                e.target.style.backgroundColor = 'pink';
            })
        </script>
    
  • 相关阅读:
    学习SpringMVC——从HelloWorld开始
    线性队列
    线性表之链表
    线性表之顺序表
    nextSibling 属性与 nextElementSibling 属性的异同
    JavaScript数组增删方法总结
    class关键字
    JS三座大山_单线程&EventLoop
    JS三座大山_闭包
    JS三座大山_原型与原型链
  • 原文地址:https://www.cnblogs.com/jianjie/p/12177882.html
Copyright © 2011-2022 走看看