如果你想禁用某个element的鼠标事件,可以给他设置一个CSS属性
pointer-events: none;
pointer-events属性的值:
- 大部分只适用于SVG,所以只记一下
none就行了。
MDN对`none`的解释
元素永远不会成为鼠标事件的target。
但是,当其后代元素的pointer-events属性指定其他值时,鼠标事件可以指向后代元素,
在这种情况下,鼠标事件将在捕获或冒泡阶段触发父元素的事件侦听器。
- 提示
使用pointer-events来阻止元素成为鼠标事件目标不一定意味着元素上的事件侦听器永远不会触发。
如果元素后代明确指定了pointer-events属性并允许其成为鼠标事件的目标,那么指向该元素的任何事件在事件传播过程中都将通过父元素,并以适当的方式触发其上的事件侦听器。
当然,位于父元素但不在后代元素上的鼠标活动都不会被父元素和后代元素捕获(鼠标活动将会穿过父元素而指向位于其下面的元素)。
该属性也可用来提高滚动时的帧频。的确,当滚动时,鼠标悬停在某些元素上,则触发其上的hover效果,然而这些影响通常不被用户注意,并多半导致滚动出现问题。对body元素应用pointer-events:none,禁用了包括hover在内的鼠标事件,从而提高滚动性能。
本文详细介绍了CSS中pointer-events属性的作用,特别是如何通过设置pointer-events为none来禁用元素的鼠标事件,同时探讨了这一设置对元素后代的影响,以及如何利用此属性提升滚动性能。
261

被折叠的 条评论
为什么被折叠?



