先上错误信息:
Unable to preventDefault inside passive event listener due to target being treated as passive. See https://www.chromestatus.com/features/5093566007214080
一个简单的页面只有这么段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);
本人资历尚浅,无法给各大社区提这个小意见
不过,这样一来,好像不用我们在手动清除默认行为了
热门评论:
-
樱花飞落ll 2017-3-2 2:04 回复:
加上* { touch-action: none; } 这句样式就去掉了
-
Kevin______ 2017-2-10 11:17 回复:
https://zhuanlan.zhihu.com/p/...
可以看看这个呃。
-
杜草原 2017-2-6 4:17 回复:
这并不是报错,event.preventDefault()也依旧生效。
passive event listener 是chrome为了提高页面的滑动流畅度而新折腾出来的一个东东。jsoncode 2017-2-7 10:47 回复:杜草原
嗯,是这样的
LikeDege 2017-2-8 4:41 回复:
这个warning还是去不掉
-
1003865572 2017-2-10 10:17 回复:
IScroll 因为这此更新 不能用了
彦_LYZ 2017-6-19 2:21 回复:1003865572
遇到同样问题,请问你怎么解决
奶油酱丶 2018-10-8 3:55 回复:
我不是很懂耶,我用了touch-action: manipulation就不影响我现有功能了,而且一直监听touchstart事件不会影响效率吗?
梵鹿 2018-11-12 10:46 回复:
elem.addEventListener(
'touchstart',
fn,
{ passive: false }
);
-
洪晓斌 2017-3-13 4:52 回复:
其实对于移动端使用是没有影响的吧
xuxhcn__喵ベ 2017-11-13 12:32 回复:
event.preventDefault();执行到这一步报错啊
hehehe 2018-1-18 10:25 回复:
你好,我也遇到了类似的问题。就是某些手机的自带浏览器打开页面,所有tap事件都不起作用。请问也是要给每个tap事件的回调函数里面加上// 判断默认行为是否可以被禁用
if (event.cancelable) {
// 判断默认行为是否已经被禁用
if (!event.defaultPrevented) {
event.preventDefault();
}
}吗?
呼啦呼啦啦啦啦 2018-3-22 10:03 回复:
我觉的是因为有的事件有默认行为。有的没有默认行为,有默认行为的event.cancelable为true,没有的为false。