首页 > web前端 > 前端问答 > javascript事件委托是什么

javascript事件委托是什么

青灯夜游
发布: 2023-01-04 09:34:45
原创
2674 人浏览过

在javascript中,事件委托就是利用冒泡的原理,将事件加到父元素或祖先元素上,触发执行效果。事件委托的优点:1、可以提高JS性能;2、可以动态添加DOM元素,不需要因为元素的变动而修改事件绑定。

javascript事件委托是什么

本教程操作环境:windows7系统、javascript1.8.5版、Dell G3电脑。

1、什么是事件委托?

事件委托就是利用冒泡的原理,将事件加到 父元素 或 祖先元素上,触发执行效果。

例:在 document 中绑定 click 事件,当 click 的对象为 按钮 btn 时,弹框显示 按钮 btn的值

<body>

<button id="btn" value="嘿嘿">哈哈</button>

<script>
  window.onload=function () {

    let btn=document.getElementById("btn")
    document.onclick=function (e) {
      // console.log(e.target)
      if(e.target===btn){
        alert(btn.value)
      }
    }

  }
</script>
</body>
登录后复制

1.webp.jpg

2、事件委托的优点

(1)可以提高 JS 性能

例:在 ul 上创建 100 个 li,点击每个 li 都要弹框显示该 li 的 value

传统写法:在每个 li 上都绑定 onclick 事件,并触发 alert 事件

事件委托:在 document 上绑定 onclick 事件,当触发 onclick 事件后,判断是不是

  • 标签,如果是,则 alert
  • 标签的值。

    (2)可以动态添加 DOM 元素,不需要因为元素的变动而修改事件绑定。

    3、事件委托需要注意的地方

    事件委托绑定的元素,最好是被监听元素的父元素,如

  • 上面的