zoukankan      html  css  js  c++  java
  • chrome 监听touch类事件报错:无法被动侦听事件preventDefault

    先上错误信息:

    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);

    本人资历尚浅,无法给各大社区提这个小意见

    不过,这样一来,好像不用我们在手动清除默认行为了

  • 相关阅读:
    10.cocos2dx C++为Sprite添加触摸事件监听器
    9.多彩的幕布layer
    8.ZOrder
    7.cocos精灵创建和绘制
    6.cocos2d设置定时器
    5.cocos2d锚点
    4.cocos场景和层的调用
    文件导入导出
    两个整数相乘是否超限
    倒置字符串函数reverse
  • 原文地址:https://www.cnblogs.com/Tohold/p/9260165.html
Copyright © 2011-2022 走看看