要捕获或取消仅在父级上的JS滚轮事件,可以使用以下代码示例:
HTML:
JavaScript:
var parent = document.getElementById("parent");
// 添加滚轮事件监听器
if (parent.addEventListener) {
// 兼容性处理
parent.addEventListener("wheel", scrollHandler, {passive: false});
} else {
parent.attachEvent("onwheel", scrollHandler);
}
function scrollHandler(event) {
// 阻止滚轮事件冒泡到子元素
event.stopPropagation();
// 取消滚轮事件的默认行为
event.preventDefault();
// 处理滚轮事件
// ...
}
在上述代码中,我们首先获取父级元素和子级元素(如果有)。然后,我们使用addEventListener或attachEvent在父级元素上添加滚轮事件监听器。使用addEventListener时,我们还传递了一个选项对象{passive: false},以确保可以使用event.preventDefault()取消滚轮事件的默认行为。
在滚轮事件处理程序中,我们使用event.stopPropagation()阻止事件冒泡到子级元素,以确保只有父级元素接收到滚轮事件。然后,我们可以根据需要处理滚轮事件。
请注意,上述代码示例是基于原生JavaScript编写的。如果您正在使用jQuery或其他JavaScript库,可能存在不同的实现方法。