使用文档级事件侦听器而不是单独的事件侦听器
Using a document level event listener instead of separated ones
想象一下以下用例:
一个页面包含多个按钮,每个按钮触发不同的功能。我看到的示例为每个按钮添加了事件侦听器。
但是,如果我将事件侦听器添加到整个文档,然后从该点中提取给定的元素,以便我知道单击了什么,并相应地调用函数,会发生什么。
在这种情况下,只有一个事件侦听器,而不是按钮的数量。
此方法会提高性能吗?
你所描述的是JavaScript事件与DOM交互方式的一个功能,称为event delegation
。
基本上,通过将侦听器添加到父元素,它可以捕获和处理来自其子元素的事件,这些事件在被激活时会"冒泡"。
与将事件侦听器添加到每个子元素的替代方法相比,此方法的资源密集程度较低。
相关文章:
- 如何在for循环中添加事件侦听器
- 未命中服务器发送的事件侦听器
- 如何覆盖原型中的事件侦听器
- 无法将事件侦听器附加到画布
- 如何在d3.js中自定义事件侦听器
- 在es6中,将带有回调的事件侦听器设置为可迭代的
- 事件侦听器未在chrome扩展中的options.js中启动
- IE8更改文本区域上的事件侦听器不工作
- 将事件侦听器添加到文档,而不是签入元素存在,然后添加事件侦听器
- javascript删除事件侦听器
- 我应该/如何清除mousemove JQuery事件侦听器
- 在JQuery中使用谷歌地图Api事件/侦听器
- 如何使用我的Jquery代码创建委托事件侦听器
- 'mousemove'画布中的事件侦听器-指针仅在最后一个矩形中更改
- 为什么此事件侦听器不工作
- 是否可以在数字输入框中的小按钮中添加事件侦听器
- 在Google Chrome扩展中添加事件侦听器
- SVG元素在转换后会丢失事件侦听器
- jQuery事件侦听器多次启动
- 如何在不删除类似侦听器的情况下从父对象中删除jQuery事件侦听器