[英]Stop click from propagating to a parent
单击特定元素时,我想调用一个函数。 当任何儿童被点击,我不想调用的函数。
我没有使用jQuery。
例:
我创建了一个模式:
<div class="fullscreen-overlay">
<div class="card">
...
</div>
</div>
我想在单击“ .fullscreen-overlay”时调用我的closeModal()
函数,但是在单击“ .card”或其任何内容时不调用它。
jsfiddle:
https://jsfiddle.net/5kuwmf9s/
研究:
我本可以为此宣誓有一个CSS属性,但是在谷歌搜索并在SO上搜索它之后,我找不到它/可能一直在想像它。 “指针事件”将其停止在目标元素上,而不是冒泡。
还有另一个答案建议将事件处理程序附加到所有捕获其事件并停止传播的子级,这似乎是不必要的。 我的孩子们是充满活力的,要保持附加处理程序会变得很复杂。
您可能已经比较了事件的target
和currentTarget
仅当当前元素是事件的原始来源时,它们才相等:
function handleClick(e){
if (e.target === e.currentTarget) {
alert('clicked!');
}
}
参考文献:
JSFiddle: https ://jsfiddle.net/u78k4k6t/
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.