javascript - 具有事件委托的多个元素上的 JavaScript addEventListener
问题描述
我想addEventListener
在事件委托的多个元素上使用。
我想要的是添加点击事件以.node
包含动态元素。
我尝试了下面的代码,但是target
当我单击.title
、.image
或时会有所不同.subtitle
。
那么有没有办法让.node
元素忽略层次结构?
提前致谢 :)
document.querySelector(".nodes").addEventListener("click", function (e) {
var target = e.target;
if (target.classList.contains("node")) {
alert("node");
}
});
.node {
width: 100px;
height: 100px;
}
.image {
width: 100px;
height: 100px;
}
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>Document</title>
</head>
<body>
<div class="nodes">
<div class="node">
<div class="image"></div>
<div class="title">title <span class="subtitle">123</span></div>
</div>
<div class="node">
<div class="image"></div>
<div class="title">title <span class="subtitle">456</span></div>
</div>
</div>
</body>
</html>
解决方案
如果你真的想知道你的 DOM 结构中的父元素之一是否属于类 node
,那么你可以使用closest(selector)
. 在下文中,我们将更改节点的样式(如果存在):-
document.querySelector(".nodes").addEventListener("click", function (e) {
var target = e.target;
const node = target.closest(".node");
if (node) {
node.style.background = 'green';
}
});
.node {
width: 100px;
height:100px;
}
.image {
width: 100px;
height: 100px;
}
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>Document</title>
</head>
<body>
<div class="nodes">
<div class="node">
<div class="image"></div>
<div class="title">title <span class="subtitle">123</span></div>
</div>
<div class="node">
<div class="image"></div>
<div class="title">title <span class="subtitle">456</span></div>
</div>
</div>
</body>
</html>
推荐阅读
- html - 具有各种向外和向内曲线的导航栏
- r - 如何从 R 中的外部函数创建稀疏矩阵?
- c++ - 将 void* 转换回数组
- mongodb - 使用 Mongoose 链接 2 个集合
- android - Android - 按下任何项目时如何取消BottomNavigationView动画
- javascript - toLocaleTimeString() 始终显示前导零
- c# - 单元测试图 SDK PageIterator
- c - 如果没有它可以实现相同的目标,为什么我需要使用 dup 进行标准输出重定向?
- android - 单击按钮时更改 TextView 的颜色
- string - 如何修改字符串中的特定字符?