事件委托,你如何理解? 【前端每日一题-28】

谈谈你对事件委托的理解,它有什么好处?写一个简单的示例。

一句话解释事件委托

利用事件冒泡机制处理指定一个事件处理程序,来管理某一类型的所有事件。

事件委托的好处

  • 利用冒泡的原理,将事件加到父级身上,触发执行效果,这样只在内存中开辟一块空间,既节省资源又减少DOM操作,提高性能
  • 可以为动态添加的元素绑定事件

案例

<ul id="ul">
  <li>111111</li>
  <li>222222</li>
  <li>333333</li>
</ul>
<button id="button">添加元素</button>

<script>
  let domUl = document.querySelector('#ul');
  let domButton = document.querySelector('#button');
  function handleUlClick(e) {
    //这里暂不考虑IE兼容
    if (e.target.nodeName.toLowerCase() === 'li') {
      console.log(e.target.innerText);
      e.target.style.background = 'red';
    }
  }
  domUl.addEventListener('click', handleUlClick);

  domButton.addEventListener('click', function() {
    let newLi = document.createElement('li');
    newLi.innerText = 'newnewnew';
    domUl.append(newLi);
  });
</script>
复制代码




















转载于:https://juejin.im/post/5d4d1f0551882577611891ef

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值