js的 addEventListener如果添加的是相同名称的事件,会被覆盖吗

在JavaScript中,使用addEventListener方法向元素添加事件监听器时,如果有多个相同的事件名称(比如多次调用addEventListener("click", function)),这些监听器不会互相覆盖,而是会累加。
这意味着所有为同一事件类型注册的监听器都会按照添加的顺序依次触发,而不是只有最后一个生效。

这是因为addEventListener方法设计为允许向一个元素添加多个事件处理程序,而不会替换之前已经存在的处理程序。
这对于需要对同一个事件执行多个操作或者多个独立逻辑的场景非常有用。如果需要移除特定的监听器,可以使用removeEventListener方法,并传入与添加时相同的事件类型和处理函数。

相比之下,老的DOM0级方法(如直接将函数赋值给element.onclick)会覆盖之前设置的事件处理函数,因为它们直接改变了元素的属性值。
这也是为什么在现代Web开发中推荐使用addEventListenerremoveEventListener来管理事件,以获得更好的控制和灵活性。


__EOF__

本文作者龙陌
本文链接https://www.cnblogs.com/longmo666/p/18233020.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角推荐一下。您的鼓励是博主的最大动力!
posted @   龙陌  阅读(303)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· .NET10 - 预览版1新功能体验(一)
点击右上角即可分享
微信分享提示