首页 > 其他分享 >CSS3 超实用属性:pointer-events (可穿透图层的鼠标事件)

CSS3 超实用属性:pointer-events (可穿透图层的鼠标事件)

时间:2024-05-29 15:45:55浏览次数:16  
标签:CSS3 顶层 鼠标 点击 事件 图层 pointer events

1、是什么

pointer-events 直译为指针事件,该属性指定在什么情况下某个DOM可以成为鼠标事件的 target。

简而言之,就是允许/禁止DOM的鼠标事件(click事件、hover事件、mouse事件等鼠标事件)

2、具体属性分析

用法分析:
pointer-events: auto | none | visiblePainted | visibleFill | visibleStroke | visible | painted | fill | stroke | all

  • auto -----默认值,与pointer-events属性未指定时的表现效果相同,对于SVG内容,该值与visiblePainted效果相同

  • none ----- 元素不再是鼠标事件的目标,鼠标不再监听当前层,而去监听下一层中的元素(这里的层指的是图层)。但是如果当前层的子元素设置了pointer-events为其它值,比如auto,鼠标还是会监听这个子元素的。

    这就是穿透点击事件的关键所在!

  • 其它属性都只适用于SVG
    visiblePainted | visibleFillvisibleStrokevisible painted
    fillstroke |all

    3、实际代码使用中案例:

    1. 禁止点击

    2. 图层覆盖覆盖后,底层图层鼠标事件失效时(无法点击),可以通过这个属性来实现,使得点击穿透,来触发底层的鼠标事件。

    4、案例

    4.1、禁止点击案例

    <!DOCTYPE html>
    <html>
        <head>
            <meta charset="UTF-8">
            <style>
                .stopClick {
                    pointer-events: none; //元素不再是鼠标事件的目标,禁止当前层的鼠标事件
                }
            </style>
        </head>
        <body>
            <ul>
                <li><a href="https://www.baidu.com/">百度</a>    </li>
                <li><a href="http://example.com" class="stopClick">一个不能点击的链接</a></li>
            </ul>
        </body>
    </html>

    第二个a标签不仅无法被点击,而且没有鼠标手形样式

    4.2、点击穿透案例

    <!DOCTYPE html>
    <html>
        <head>
            <meta charset="UTF-8">
            <style>
                .bottom {
                    background: yellow;
                    width: 100px;
                    height: 100px;
                }
                
                .top {
                    width: 100px;
                    height: 100px;
                    position: absolute;
                    top: 0;
                    left: 0;
                    z-index: 100;
                    display: flex;
                    justify-content: center;
                    align-items: center;
                     /*不再监听当前图层的鼠标事件,而去监听下一层中元素的鼠标事件*/
                    pointer-events: none; 
    
                }
                .top b{
                    display:inline-block;
                    margin: 0 auto;
                     /*子元素修改pointer-events,允许触发鼠标事件*/
                    pointer-events:auto;  
                }
            </style>
        </head>
        <body>
            <!-- 下方div -->
            <div class="bottom">
                <a href="http://www.baidu.com">下一层--百度</a>
            </div>
            <!-- 上方div -->
            <div class="top" onclick="topSay()">
                <b id="topTxt">顶层</b>
            </div>
            
            <script>
                document.getElementById("topTxt").onclick = function(evt){
                    alert('顶层内b元素的事件!');
                    evt.stopPropagation();   //阻止了事件的向上传播,否则就会触发父容器的alert事件。
                }
                function topSay(){
                   alert('顶层事件')
                }
            </script>
        </body>
    
    </html>

    分析如下
    原本底层被顶层覆盖,使得底层的百度跳转事件无法被触发。

    但是这里顶层设置了pointer-events: none;,使得顶层的鼠标事件被禁止,浏览器转而去监听下一层的鼠标事件,这就使得百度跳转事件又可以生效了。

    由于顶层内的子元素b继承了顶层的pointer-events: none;,使得b也无法触发鼠标事件,但是,b元素其自身又重新设置了pointer-events:auto;,使得b又可以触发鼠标事件了。

    在b元素的点击事件上,如果不加evt.stopPropagation(),去阻止事件冒泡,通过点击b,也会触发父容器的点击事件

    5、兼容性

      • IE  11+
      • Firefox  3.6+
      • Chrome 4.0+
      • Safari  6.0
      • Opera  15.0
      • iOS Safari 6.0
      • Android Browser 2.1+
      • Android Chrome 18.0+

标签:CSS3,顶层,鼠标,点击,事件,图层,pointer,events
From: https://www.cnblogs.com/houxianzhou/p/18220412

相关文章

  • 如何在AutoCAD中添加图层前缀
    在AutoCAD绘图过程中,合理地管理图层是确保绘图效率和清晰度的关键。有时,我们可能需要为图层添加统一的前缀,以便于区分不同的图层组或满足特定的绘图标准。本文将介绍如何使用AutoCAD.NETAPI创建一个简单的工具,以自动添加图层前缀。环境准备在开始之前,请确保您具备以下条件:......
  • 代码雨(coderain)源码(html5+css3+javascript,原创)
     大家看过黑客帝国的代码雨吗?本人自己写了一个,效果还可以。演示效果请见https://www.lanbaoshi.site/coderain.htm下面上代码:<!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><htmlxmlns="htt......
  • css3实现类似地图定位循环扩散光圈效果
    html123456789<divclass="icon-warnCom">        <iconclass="icon-warns"><iclass="dot"></i><iclass="pulse"></i></icon>    </div>    <divcla......
  • Go - Choosing a value or pointer receiver
    ChoosingavalueorpointerreceiverTherearetworeasonstouseapointerreceiver.Thefirstissothatthemethodcanmodifythevaluethatitsreceiverpointsto.Thesecondistoavoidcopyingthevalueoneachmethodcall.Thiscanbemoreefficien......
  • Django视图层——2HttpReqeust对象&QueryDict对象
    HttpReqeust对象服务器接收到http协议的请求后,会根据报文创建HttpRequest对象视图函数的第一个参数是HttpRequest对象在django.http模块中定义了HttpRequest对象的API属性下面除非特别说明,属性都是只读的path:一个字符串,表示请求的页面的完整路径,不包含域名method:......
  • 双指针(Two Pointers)
    双指针顾名思义,就是同时使用两个指针,在序列、链表结构上指向的是位置,在树、图结构中指向的是节点,通过或同向移动,或相向移动来维护、统计信息。如果不和其他数据结构结合使用,双指针维护区间信息的最简单模式就是维护具有一定单调性,新增和删去一个元素都很方便处理的信息,就比如......
  • 允许鼠标响应 css,pointer-events: auto; 和 pointer-events: all; 有什么区别,用哪个
    在CSS中,`pointer-events:auto;`和`pointer-events:all;`实际上并不存在`pointer-events:all;`这个值,因此不用考虑哪个更好。正确的用法是`pointer-events:auto;`。###`pointer-events`属性的概述`pointer-events`属性用于控制一个元素是否响应鼠标事件(如点击、悬停......
  • CSS3随机背景图片切换特效
    Tips:当你看到这个提示的时候,说明当前的文章是由原emlog博客系统搬迁至此的,文章发布时间已过于久远,编排和内容不一定完整,还请谅解`CSS3随机背景图片切换特效日期:2018-5-16阿珏css浏览:4572次评论:16条css3的随机背景图片淡入淡出切换特效 演示效果如本篇文章背景所示......
  • 用CSS3绘制iPhone手机
    Tips:当你看到这个提示的时候,说明当前的文章是由原emlog博客系统搬迁至此的,文章发布时间已过于久远,编排和内容不一定完整,还请谅解`用CSS3绘制iPhone手机日期:2017-7-3阿珏css浏览:1825次评论:1条先上效果图,先睹为快。(这绝对不是一张图片。恩~这话怎么怪怪的~)......
  • 简单的css3头像旋转与3D旋转效果
    Tips:当你看到这个提示的时候,说明当前的文章是由原emlog博客系统搬迁至此的,文章发布时间已过于久远,编排和内容不一定完整,还请谅解`简单的css3头像旋转与3D旋转效果日期:2017-7-10阿珏css浏览:3896次评论:2条经常会在一些网站看到评论区,评论人的头像当鼠标经过会360°旋......