JS 事件委托

什么是事件委托

  • 事件委托,就是将本来 A 处理的事情,委托给 B 来处理,也称为事件代理。
  • 每个函数都是对象,占用内存。内存中的对象越多,性能越差。解决处理过多问题的办法是事件委托。
  • 事件委托是通过事件冒泡来实现的,只指定一个事件处理程序,就可以管理某一类型的所有事件。

事件委托的实现

示例1

需求:当鼠标悬浮在 li 元素上,li 元素背景变成红色,离开时,去掉背景
不使用事件委托

<body>
    <ul class="ul">
        <li>1</li>
        <li>2</li>
        <li>3</li>
        <li>4</li>
        <li>5</li>
        <li>6</li>
        <li>7</li>
        <li>8</li>
        <li>9</li>
        <li>10</li>
    </ul>
    <script>
        window.onload = () => {
            let oUl = document.querySelector('.ul')
            let aLi = oUl.getElementsByTagName('li')

            for (let i = 0; i < aLi.length; i++) {
                aLi[i].onmouseover = function () {
                    this.style.background = 'red';
                }
                aLi[i].onmouseout = function () {
                    this.style.background = '';
                }
            }
        }
    </script>
</body>

这种方法需要 通过 for 循环遍历每个 li ,占用监听内存,如果 li 较多,会导致性能变差。而且不能监听动态元素。

使用事件委托

<script>
        window.onload = () => {
            let oUl = document.querySelector('.ul')
            oUl.onmouseover = function (e) {
                e = e || window.event
                let target = e.target || e.srcElement
                if (target.nodeName.toLowerCase() === 'li') {
                    target.style.background = 'red'
                }
            }
            oUl.onmouseout = function (e) {
                e = e || window.event
                let target = e.target || e.srcElement
                if (target.nodeName.toLowerCase() === 'li') {
                    target.style.background = ''
                }
            }
        }
    </script>
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 什么是事件委托? 举个例子,我们要实现点击 li 时打印其id 一般我们会给每一个li绑定一个事件处理函数 这种方...
    寒o_0阅读 3,318评论 0 1
  • 什么是事件委托 事件委托就是将子级事件委托给父级,父级监听这个事件,如果事件触发,父级会通过 event.targ...
    bestCindy阅读 1,274评论 0 0
  • 1. 事件是什么 DOM事件即为Event对象。Event对象代表事件的状态,比如事件在其中发生的元素、键盘按键的...
    取个名字还真滥阅读 1,891评论 0 1
  • 起因: 1、这是前端面试的经典题型,要去找工作的小伙伴看看还是有帮助的; 2、其实我一直都没弄明白,写这个一是为了...
    Bonne_nuit阅读 2,187评论 0 2
  • 第一组:杨昊 真干货——Js事件委托 一份好的代码,不仅仅要写的美观,还要性能卓越。事件委托可以说就是这样一种—...
    胡諾阅读 3,966评论 1 3

友情链接更多精彩内容