如何处理多个事件侦听器
How to handle more than one eventListener?
我有两个这样的div:
<div id="sun" > </div> <div id="thu" > </div>
我想一旦其中一个点击了eventListener
:
document.getElementById(currentId).addEventListener("click",function(e){});
在知道div 的 ID 的情况下触发选定的一个。
你需要这个:
function eventHandler(e) {
//what needs to be done after user clicks the divs will come here
}
document.getElementById('sun').addEventListener("click", eventHandler, false);
document.getElementById('thu').addEventListener("click", eventHandler, false);
这真的很简单。基本上,事件回调函数的上下文是单击的实际 html 元素。因此,"this"选择器是事件的实际来源。
document.getElementById(currentId).addEventListener("click",function(e){
var id=this.getAttribute('id');
});
循环访问元素并向它们添加 onclick 事件。或者只是单独添加侦听器。
document.querySelectorAll("#sun, #thu").forEach(el =>
el.onclick = () => {
console.log(el.id)
}
);
我认为您正在为两个div寻找一个共同的事件处理程序。
如果是,那么您可以通过为两个div 提供公共类,然后通过类选择器注册事件处理程序来实现这一点,如下所示:
网页代码:
<div id="sun" class="myClass"> </div>
<div id="thu" class="myClass" > </div>
Java脚本代码:
var classname = document.getElementsByClassName("myClass");
for(var i=0;i<classname.length;i++){
classname[i].addEventListener('click', event_handler_name, false);
}
或
$('.myClass').click(event_handler_name);
jQuery为你做了循环部分,就像你需要在普通的javascript中做的那样。
相关文章:
- 如何在for循环中添加事件侦听器
- 未命中服务器发送的事件侦听器
- 如何覆盖原型中的事件侦听器
- 无法将事件侦听器附加到画布
- 如何在d3.js中自定义事件侦听器
- 在es6中,将带有回调的事件侦听器设置为可迭代的
- 事件侦听器未在chrome扩展中的options.js中启动
- IE8更改文本区域上的事件侦听器不工作
- 将事件侦听器添加到文档,而不是签入元素存在,然后添加事件侦听器
- javascript删除事件侦听器
- 我应该/如何清除mousemove JQuery事件侦听器
- 在JQuery中使用谷歌地图Api事件/侦听器
- 如何使用我的Jquery代码创建委托事件侦听器
- 'mousemove'画布中的事件侦听器-指针仅在最后一个矩形中更改
- 为什么此事件侦听器不工作
- 是否可以在数字输入框中的小按钮中添加事件侦听器
- 在Google Chrome扩展中添加事件侦听器
- SVG元素在转换后会丢失事件侦听器
- jQuery事件侦听器多次启动
- 如何在不删除类似侦听器的情况下从父对象中删除jQuery事件侦听器