css3 穿透属性 pointer-events

发布时间:2022-12-26 21:01:28 作者:yexindonglai@163.com 阅读(1529)

pointer-events 是一个蛮有趣的 CSS3 屬性,雖然主要是針對 SVG ,但其中幾個屬性應用在 div 上也是頗有意思。顧名思義,這是一個針對滑鼠事件的屬性,默认值为:auto,若值為 none,則可以穿透该元素,点击到下方的元素。除了 auto 和 none,這是完整的屬性列表:pointer-events:

  • auto
  • none
  • visiblePainted
  • visibleFill
  • visibleStroke
  • visible
  • painted
  • fill
  • stroke
  • all
  • inherit

除了 auto 與 none,其他都是控制 SVG 的屬性,若採用預設值,則 SVG 就是以 visiblePainted 來表現

举例,如下代码:

  1. <div class="ybox"></div>
  2. <div class="gbox"></div>
  3. <style>
  4. .ybox {
  5. background: rgba(255, 200, 0, .8);
  6. margin: 20px;
  7. z-index: 3;
  8. }
  9. .gbox {
  10. background: rgba(0, 220, 170, .8);
  11. margin: -80px 40px 20px;
  12. z-index: 2;
  13. }
  14. .gbox:hover{
  15. background: rgba(255, 50, 50, .8);
  16. }
  17. </style>

首先看到 pointer-events: auto,就是我們一般常見的,一個 div 被另外一個 div 遮住,就無法進行點擊或 hover 的動作
当鼠标在两个矩形外面时,矩形的颜色是正常的颜色

当鼠标移动到绿色的矩形上面时,触发 hover 事件,会将矩形变为红色

将鼠标移动到黄色的矩形上时,下面的矩形又恢复成了绿色

修改,這時候如果我們把 ybox 增加 pointer-events: none;,就會發現底下的 gbox 可以 hover 了!

  1. .ybox {
  2. background: rgba(255, 200, 0, .8);
  3. margin: 20px;
  4. z-index: 3;
  5. pointer-events: none;
  6. }

这时候将鼠标移动到整个 gbox 上都可以触发 hover 事件

接下来我们将鼠标移动到下面的 gbox 元素上,可以看到,已经穿透了黄色的矩形,触发了下面的绿色矩形的 hover 事件,使其变为了红色

其他属性

至於其他的屬性,在這邊稍微做一些介紹,根據 這篇的解釋,可以知道其他屬性是這樣解釋:

visiblePainted:
只適用於 SVG。元素只有在以下情況才會成為鼠標事件的目標:visibility 屬性值為 visible,且鼠標指針在元素內部,且 fill 屬性指定了 none 之外的值、visibility 屬性值為 visible,鼠標指針在元素邊界上,且 stroke 屬性指定了none 之外的值。

visibleFill:
只適用於 SVG。只有在元素 visibility 屬性值為 visible,且鼠標指針在元素內部時,元素才會成為鼠標事件的目標,fill屬性的值不影響事件處理。

visibleStroke:
只適用於 SVG。只有在元素 visibility 屬性值為 visible,且鼠標指針在元素邊界時,元素才會成為鼠標事件的目標,stroke 屬性的值不影響事件處理。

visible:
只適用於 SVG。只有在元素 visibility 屬性值為 visible,且鼠標指針在元素內部或邊界時,元素才會成為鼠標事件的目標,fill 和 stroke 屬性的值不影響事件處理。

painted:
只適用於 SVG。元素只有在以下情況才會成為鼠標事件的目標:鼠標指針在元素內部,且 fill 屬性指定了 none 之外的值、鼠標指針在元素邊界上,且 stroke 屬性指定了 none 之外的值。

visibility屬性的值不影響事件處理。

fill:
只適用於 SVG。只有鼠標指針在元素內部時,元素才會成為鼠標事件的目標,fill 和 visibility 屬性的值不影響事件處理。

stroke:
只適用於 SVG。只有鼠標指針在元素邊界上時,元素才會成為鼠標事件的目標,stroke 和 visibility 屬性的值不影響事件處理。

all:
只適用於 SVG。只有鼠標指針在元素內部或邊界時,元素才會成為鼠標事件的目標,fill、stroke 和 visibility 屬性的值不影響事件處理。

关键字前端