其他分享
首页 > 其他分享> > 0173 事件委托:原理、作用

0173 事件委托:原理、作用

作者:互联网

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

1.3.8.1 什么是事件委托

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

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

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


生活中的代理:


js事件中的代理:


1.3.8.2 事件委托的原理

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


1.3.8.3 事件委托的作用

    <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>

标签:0173,委托,知否,弹框,ul,事件,元素,原理,冒泡
来源: https://www.cnblogs.com/jianjie/p/12177882.html