gpt4 book ai didi

javascript - 防止目标事件及其父事件

转载 作者:行者123 更新时间:2023-11-30 16:45:46 26 4
gpt4 key购买 nike

我有这段代码,我用它从每个具有这个类名的元素中删除一个类名“joker”:http://jsfiddle.net/ffz30knn/1/

是否有可能(仅使用 vanilla JS)在目标元素及其父元素上阻止此事件,所以当我单击 <span class="joker">one</span> 时在里面 <div class="joker"></div>它将从具有此类的其他元素中删除“joker”类,但不会从该 span 元素中删除它包装的 div?

谢谢。

这是当前代码:

function removeClass(classToRemove) {
var elems = document.getElementsByClassName(classToRemove);
console.log(elems.length);
if (!elems) return;
for (var i = elems.length - 1; i >= 0; i--) {
var elem = elems[i];
elem.className = elem.className.replace(/(?:^|\s)joker(?!\S)/g, '');
}
}
window.onload = function() {
document.onclick = function() {
removeClass("joker");
};
};
div {
background: silver;
padding: 3px 8px;
margin: 5px;
}
span {
background: blue;
padding: 3px 8px;
color: white;
}
.joker {
background: black;
color: red;
}
<div class="one two three joker"><span class="joker">one</span>
</div>
<div class="one two three"><span>two</span>
</div>
<div class="one two three joker"><span class="joker">three</span>
</div>
<div class="one two three"><span>four</span>
</div>

最佳答案

如果我知道你想从除你点击的元素之外的每个元素中删除类 joker

在你的 removeClass 函数中你可以检查它是否是同一个元素

function removeClass(classToRemove) {
var elems = document.getElementsByClassName(classToRemove);
console.log(elems.length);
if (!elems) return;
for (var i = elems.length - 1; i >= 0; i--) {
var elem = elems[i];
if(elem != this)
elem.className = elem.className.replace(/(?:^|\s)joker(?!\S)/g, '');
}
}

而且我猜你可以通过执行 Element.parentElement 检查父元素,这样你会:

if(elem != this && elem != this.parentElement)

关于javascript - 防止目标事件及其父事件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31265695/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com