没有循环的多个事件侦听器
Multiple event listener without loops
我的项目中有相同的结构!
<!-- menu structure-->
<nav class="menu">
<a class="trigger" href="#">item</a>
<a class="trigger" href="#">item</a>
<a class="trigger" href="#">item</a>
<a class="trigger" href="#">item</a>
<a class="trigger" href="#">item</a>
</nav>
我想为所有触发器添加一个事件侦听器,但我找到的解决方案是使用循环,这里是 js
menuitens = document.querySelectorAll('.trigger');
menuitens.addEventListener("click", function (){});
要让单个事件侦听器将其绑定到容器:
document.querySelector('.menu').addEventListener('click', function(e) {
e.preventDefault();
if (!e.target.classList.contains('trigger')) return;
alert('.trigger clicked');
});
https://jsfiddle.net/t6frderh/
您可以侦听容器元素上的所有单击事件:
document.querySelector(".menu").addEventListener(
'click',
function(e)
{
if (e.target.classList.contains('target'))
{
// do stuff ....
}
}
);
相关文章:
- 如何在for循环中添加事件侦听器
- 未命中服务器发送的事件侦听器
- 如何覆盖原型中的事件侦听器
- 无法将事件侦听器附加到画布
- 如何在d3.js中自定义事件侦听器
- 在es6中,将带有回调的事件侦听器设置为可迭代的
- 事件侦听器未在chrome扩展中的options.js中启动
- IE8更改文本区域上的事件侦听器不工作
- 将事件侦听器添加到文档,而不是签入元素存在,然后添加事件侦听器
- javascript删除事件侦听器
- 我应该/如何清除mousemove JQuery事件侦听器
- 在JQuery中使用谷歌地图Api事件/侦听器
- 如何使用我的Jquery代码创建委托事件侦听器
- 'mousemove'画布中的事件侦听器-指针仅在最后一个矩形中更改
- 为什么此事件侦听器不工作
- 是否可以在数字输入框中的小按钮中添加事件侦听器
- 在Google Chrome扩展中添加事件侦听器
- SVG元素在转换后会丢失事件侦听器
- jQuery事件侦听器多次启动
- 如何在不删除类似侦听器的情况下从父对象中删除jQuery事件侦听器