无法阻止被动事件侦听器内的默认

3zz*_*zzy 40 javascript jquery html-framework-7

我正在使用Framework7可排序列表,它运行良好,只是在列表更改时不会触发事件.

所以我正在尝试一些内置事件:

$('.sortable-handler').on('touchstart', function (e) {
    e.preventDefault();
    alert('touchstart');
});

$('.sortable-handler').on('touchmove', function (e) {
    e.preventDefault();
    console.log('touchmove');
});

$('.sortable-handler').on('touchcancel', function (e) {
    e.preventDefault();
    console.log('touchcancel');
});

$('.sortable-handler').mouseleave(function (e) {
    e.preventDefault();
    console.log('mouseleave');
});
Run Code Online (Sandbox Code Playgroud)

..但我得到的是:

由于目标被视为被动,因此无法阻止被动事件侦听器内的默认.请参阅 https://www.chromestatus.com/features/5093566007214080

我应该寻找哪种事件来获取每种类型的更新列表?

Ric*_*ers 61

看到这篇博文.如果您preventDefault每次都打电话,touchstart那么您还应该有一个CSS规则来禁用触摸滚动

.sortable-handler {
  touch-action: none;
}
Run Code Online (Sandbox Code Playgroud)

  • @Rick Byers,如何为转盘mousewheel DOMMouseScroll添加preventDefault()。 (2认同)

Hal*_*cht 15

在普通 JS 中添加{ passive: false }为第三个参数

document.addEventListener('wheel', function(e) {
    e.preventDefault();
    doStuff(e);
}, { passive: false });
Run Code Online (Sandbox Code Playgroud)

  • 如果您还需要使用捕获而不是冒泡(意味着第三个参数将为“true”),则第三个参数应该为“{capture: true, Passive:false}”。有关第三个参数的选项的完整列表,请参阅 https://developer.mozilla.org/en-US/docs/Web/API/EventTarget/addEventListener。 (3认同)
  • 我该如何做才能对听众做出反应 (2认同)

ran*_*uch 12

为了我

document.addEventListener("mousewheel", this.mousewheel.bind(this), { passive: false });
Run Code Online (Sandbox Code Playgroud)

做到了绝招({ passive: false }部分)。

  • 它对我有用,无需绑定 mouseweel。我用它代替了 e.preventDefault。`window.addEventListener('wheel', { 被动: false })` (4认同)

Agu*_*bat 10

要在用户在新位置释放当前排序元素时处理 Framework7 中的可排序列表,您可以使用以下代码:

  $$('li').on('sortable:sort',function(event){
    alert("From " + event.detail.startIndex + " to " + event.detail.newIndex);
  });
Run Code Online (Sandbox Code Playgroud)

小提琴:https : //jsfiddle.net/0zf5w4y7/

  • 他们有。他们在页面底部提到了它。请参阅文档 https://framework7.io/docs/sortable-list.html#sortable-events (2认同)

Sau*_*nki 8

我在使用猫头鹰旋转和滚动图像时遇到这个问题。

因此,只需在页面中添加以下 CSS 即可解决问题。

.owl-carousel {
-ms-touch-action: pan-y;
touch-action: pan-y;
}
Run Code Online (Sandbox Code Playgroud)

或者

.owl-carousel {
-ms-touch-action: none;
touch-action: none;
}
Run Code Online (Sandbox Code Playgroud)

  • 感谢您的回答,我专门寻找猫头鹰狂欢节,这就像一个魅力:) (2认同)