passive event listener

前段时间在做图片随着滚轮缩放时,遇到一个问题。监听元素的滚滚动,同时还滚动了页面。后来准备使用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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值