javascript事件委托是什么


本文摘自PHP中文网,作者青灯夜游,侵删。

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

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

1、什么是事件委托?

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

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

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

<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 事件后,判断是不是 <li> 标签,如果是,则 alert <li> 标签的值。

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

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

事件委托绑定的元素,最好是被监听元素的父元素,如 <li> 上面的 <ul>、<tr> 上面的 <table> 等。

因为 事件冒泡 的过程也要耗时,越接近顶层,事件的「事件传播链」就越长,也就越耗时。

4、事件冒泡 和 事件捕获

2.webp.jpg

如图,事件冒泡是从子元素向父元素传递事件,一层一层,事件委托就是利用了冒泡原理;事件捕获是从 DOM 最高层对象一层一层往子元素传播。

更多编程相关知识,请访问:编程视频!!

以上就是javascript事件委托是什么的详细内容,更多文章请关注木庄网络博客

相关阅读 >>

javascript未知错误怎么查

详解javascript中async/await是如何工作的

javascript中$是什么意思

settimeout和setinterval之间有什么区别?

javascript函数式编程中代码组合(compose)的理解

jquery中prop什么意思

javascript可以写在body里吗

一起看看javascript异步剪贴板api

javascript中字符串转数组的方法是什么

dom节点和元素之间有什么区别

更多相关阅读请进入《javascript》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...