javascript - 如何解决移动端的滑动事件总是出现无法侦听被动事件?
大家讲道理
大家讲道理 2017-04-11 11:04:17
0
3
523

使用 swiper.js jquerymobile.js 等移动端js库的时候,如果使用了滑动事件,不时会看到报错:“
Unable to preventDefault inside passive event listener due to target being treated as passive”。但奇怪的是脚本运行正常,而且在不同的库和项目中我都能看见这种情况,我觉得不是个例。

所以我想问一下,出现这个问题通常是什么原因,各位又是如何解决、排查这个问题的?

大家讲道理
大家讲道理

光阴似箭催人老,日月如移越少年。

membalas semua(3)
左手右手慢动作

遇到了和你一样的问题,没人来回答啊?
我的代码是:


<p class="demo">
    <p>点击这里</p>
</p>
document.addEventListener('touchmove', function(event) {
    var e = event||window.event;
    var p = event.target.closest('.demo');
    if (!p) {
        e.preventDefault();
    }
},false);

错误:

Unable to preventDefault inside passive event listener due to target being treated as passive. See https://www.chromestatus.com/...

刘奇

在swiper的初始项里面加上passiveListeners: false,即可,具体搜一下passiveListeners

大家讲道理

如图所示

而这些库也用到了这个咯。所以你在里面写preventDefault方法都是无效的
证据如下

Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan
Tentang kita Penafian Sitemap
Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!