为什么事件处理程序被解雇两次



如果我折叠或展开"id-1";则处理程序工作正常。

如果我崩溃或膨胀";id-1-1";则触发两个处理程序:一个用于";id-1";第二个用于";id-1-1";。

为什么该事件因";id-1";即使没有采取任何行动?

const myCollapsible = document.querySelectorAll('.collapse');
myCollapsible.forEach(myOne => {
myOne.addEventListener('shown.bs.collapse', function() {
console.log('shown ' + this.id);
});
myOne.addEventListener('hidden.bs.collapse', function() {
console.log('hidden ' + this.id);
});
});
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link href="https://cdn.jsdelivr.net/npm/bootstrap@5.2.0-beta1/dist/css/bootstrap.min.css" rel="stylesheet">
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap-icons@1.8.2/font/bootstrap-icons.css">
</head>
<body>
<div>
<a class="bi-caret-right-fill link-dark text-decoration-none me-2" data-bs-toggle="collapse" href="#id-1"></a>
<a href="#">id-1</a>
<div class="collapse ms-4" id="id-1">
<div>
<a class="bi-caret-right-fill link-dark text-decoration-none me-2" data-bs-toggle="collapse" href="#id-1-1"></a>
<a href="#">id-1-1</a>
<div class="collapse ms-4" id="id-1-1">
text
</div>
</div>
<div>
<a class="bi-caret-right-fill link-dark text-decoration-none me-2" data-bs-toggle="collapse" href="#id-1-2"></a>
<a href="#">id-1-2</a>
<div class="collapse ms-4" id="id-1-2">
text
</div>
</div>
<div>
<a class="bi-caret-right-fill link-dark text-decoration-none me-2" data-bs-toggle="collapse" href="#id-1-3"></a>
<a href="#">id-1-3</a>
<div class="collapse ms-4" id="id-1-3">
text
</div>
</div>
</div>
</div>
<div>
<a class="bi-caret-right-fill link-dark text-decoration-none me-2" data-bs-toggle="collapse" href="#id-2"></a>
<a href="#">id-2</a>
<div class="collapse ms-4" id="id-2">
text
</div>
</div>
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.2.0-beta1/dist/js/bootstrap.bundle.min.js"></script>
</body>
</html>

您需要从您的孩子e.stopPropagation()到顶级家长。

您可以在stopPropagation 上找到更多信息

const myCollapsible = document.querySelectorAll('.collapse');
myCollapsible.forEach(myOne => {
myOne.addEventListener('shown.bs.collapse', function(e) {
e.stopPropagation();
console.log('shown ' + this.id);
});
myOne.addEventListener('hidden.bs.collapse', function(e) {
e.stopPropagation();
console.log('hidden ' + this.id);
});
});
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link href="https://cdn.jsdelivr.net/npm/bootstrap@5.2.0-beta1/dist/css/bootstrap.min.css" rel="stylesheet">
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap-icons@1.8.2/font/bootstrap-icons.css">
</head>
<body>
<div>
<a class="bi-caret-right-fill link-dark text-decoration-none me-2" data-bs-toggle="collapse" href="#id-1"></a>
<a href="#">id-1</a>
<div class="collapse ms-4" id="id-1">
<div>
<a class="bi-caret-right-fill link-dark text-decoration-none me-2" data-bs-toggle="collapse" href="#id-1-1"></a>
<a href="#">id-1-1</a>
<div class="collapse ms-4" id="id-1-1">
text
</div>
</div>
<div>
<a class="bi-caret-right-fill link-dark text-decoration-none me-2" data-bs-toggle="collapse" href="#id-1-2"></a>
<a href="#">id-1-2</a>
<div class="collapse ms-4" id="id-1-2">
text
</div>
</div>
<div>
<a class="bi-caret-right-fill link-dark text-decoration-none me-2" data-bs-toggle="collapse" href="#id-1-3"></a>
<a href="#">id-1-3</a>
<div class="collapse ms-4" id="id-1-3">
text
</div>
</div>
</div>
</div>
<div>
<a class="bi-caret-right-fill link-dark text-decoration-none me-2" data-bs-toggle="collapse" href="#id-2"></a>
<a href="#">id-2</a>
<div class="collapse ms-4" id="id-2">
text
</div>
</div>
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.2.0-beta1/dist/js/bootstrap.bundle.min.js"></script>
</body>
</html>

最新更新