chrome 监听touch类事件报错:无法被动侦听事件preventDefault

Posted 弓弧名家_玄真君

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了chrome 监听touch类事件报错:无法被动侦听事件preventDefault相关的知识,希望对你有一定的参考价值。

转自:https://segmentfault.com/a/1190000007621605

先上错误信息:

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

一个简单的页面只有这么段js

document.addEventListener('touchstart', function(event) 
    event.preventDefault();
, false);

报的一个好错误,真是日了狗了,一直这么写的代码,什么情况?
原来,是新版chrome,给这个preventDefault返回了naive,不再是清除浏览器默认行为了。
那这怎么搞?
现在mdn上搜索一番:
event.cancelable 浏览器默认行为是否可以被禁用
event.defaultPrevented 浏览器默认行为是否已经被禁用
好像mdn上的event.preventDefault()方法还没更新到最新
那这就可以解决问题了,如果event.cancelable=false,是什么意思?不让开发者主动去禁用么?
但是event.defaultPrevented也是false,这个又怎么说?明明是没有清除默认行为,却又禁止清除默认行为!!!

好吧,我是一个渺小的开发者,我只能该自己的代码:

document.addEventListener('touchstart', function(event) 
    // 判断默认行为是否可以被禁用
    if (event.cancelable) 
        // 判断默认行为是否已经被禁用
        if (!event.defaultPrevented) 
            event.preventDefault();
        
    
, false);

以上是关于chrome 监听touch类事件报错:无法被动侦听事件preventDefault的主要内容,如果未能解决你的问题,请参考以下文章

无法阻止被动事件监听器jQuery Mobile中的默认

由于目标被视为被动,无法在被动事件侦听器中阻止默认值?为啥滚动时出现此错误?

React 中touch和click事件冲突

什么是被动事件监听器?

iOS 手势识别

在 onWheel 事件中使用 event.preventDefault 时,如何规避 reactjs 中的“被动事件监听器”