码迷,mamicode.com
首页 > 其他好文 > 详细

0173 事件委托:原理、作用

时间:2020-01-10 20:47:25      阅读:105      评论:0      收藏:0      [点我收藏+]

标签:控制   var   dom   弹框   mamicode   特性   doc   事件冒泡   jquer   

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

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>

0173 事件委托:原理、作用

标签:控制   var   dom   弹框   mamicode   特性   doc   事件冒泡   jquer   

原文地址:https://www.cnblogs.com/jianjie/p/12177882.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!