前段时间在做图片随着滚轮缩放时,遇到一个问题。监听元素的滚滚动,同时还滚动了页面。后来准备使用preventDefault阻止浏览器默认行为。却报了Unable to preventDefault inside passive event listener due to target being treated as passive
错误。
查找资料发现对addEventListener还是不够了解。
addEventListener的第三个参数也可以是一个对象。
这个对象有以下属性
capture
: Boolean,表示
listener会在该类型的事件捕获阶段传播到该
EventTarget` 时触发。once
: Boolean,表示listener 在添加之后最多只调用一次。如果是
true,
listener
会在其被调用之后自动移除。passive
:Boolean,设置为true时,表示listener
永远不会调用preventDefault()。如果 listener 仍然调用了这个函数,客户端将会忽略它并抛出一个控制台警告,这个警告就是上面的报错。
passive
参数关系到了Passive Event Listeners(ps:请科学上网)
当遇到这个报错的时候,就是因为passive属性被默认设置成了true用来提升滚动的性能。不考虑滚动性能下,可以直接手动将passive
设置成false
移动端可以使用better-scroll
MDN:addEventListener