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

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

时间:2024-11-16 10:41:23浏览次数:1  
标签: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 | visibleFillvisibleStrokevisiblepainted
      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/huaan011/p/18549107

相关文章

  • 检测 HTML5\CSS3\JAVASCRIPT 在浏览器的适应情况
    https://www.cnblogs.com/czhyuwj/p/4796690.html CSS3SelectorsTest:这是CSS3.INFO网站提供的css选择器测试页面,它能够详细显示当前浏览器对所有CSS3选择器的支持情况。启动测试,浏览器会自动测验,并已列表的方式显示当前浏览器对所有css3选择器的支持情况  http://tool......
  • 数据可视化CSS3
    可视化-解决方案2D动画-transform坐标系transform-origin3D动画-transform3D旋转-rotateZ、rotateX、rotateY3D旋转-rotate3d3D透视-perspective3D位移-translateX、translateY、translateZ3D位移-translate3d3D缩放-scaleX、scaleY、scaleZ3D缩放-scale3d......
  • 如果在整个项目中 QTcpSocket 被多次引用,并且多个对象或类需要共享同一个 QTcpSocket
    如果在整个项目中QTcpSocket被多次引用,并且多个对象或类需要共享同一个QTcpSocket实例,那么使用QSharedPointer<QTcpSocket>是一个不错的选择。以下是使用QSharedPointer<QTcpSocket>的优点、注意事项以及一些替代方案的建议。为什么推荐使用QSharedPointer<QTcpSo......
  • css3D变换用法
    文章目录CSS3D变换详解及代码案例一、CSS3D变换的基本概念二、3D变换的开启与景深设置三、代码案例CSS3D变换详解及代码案例CSS3D变换是CSS3中引入的一种强大功能,它允许开发者在网页上创建三维空间中的动画和交互效果。通过CSS3D变换,你可以实现元素的3D位移、旋转......
  • CSS3过渡
     CSS过渡能够做出一些好看动画效果,无需使用Flash动画或JavaScript使用语法:         transition: property   time  speedChange  delayTime,  ...属性:           ①property:过渡的属性         ②time:过渡的时间 ......
  • openlayers wfs图层 zoom控制显示
    openlayerswfs图层zoom控制显示在OpenLayers中,使用WFS(WebFeatureService)图层时,你可以通过设置最小和最大缩放级别(minZoom 和 maxZoom 选项)来控制该图层在地图上的显示和请求频率。以下是一个简单的例子,展示如何设置WFS图层的缩放级别:import'ol/ol.css';......
  • CSS3中动画的使用animation
    1.基本使用2.其他属性3.复合属性......
  • CSS3实现放大镜效果
    市面上基本上所有的购物平台、商城上的商品详情页,对于商品的图片都是有放大功能。那么这个功能主要是怎么实现的呢?CSS3实现放大镜效果主要依赖于CSS的一些高级特性,如transform、transition和::before伪元素等其实代码并没有多少,这里用了6款静态资源图片作为示例,但是每一款都需要......
  • CSS3实现放大镜效果
    市面上基本上所有的购物平台、商城上的商品详情页,对于商品的图片都是有放大功能。那么这个功能主要是怎么实现的呢?CSS3实现放大镜效果主要依赖于CSS的一些高级特性,如transform、transition和::before伪元素等其实代码并没有多少,这里用了6款静态资源图片作为示例,但是每一款都需......
  • 纯HTML5+CSS3实现一棵自己跳舞的树
    代码没有多少,也没有用到任何图片,就实现了一棵可以自己跳舞的树。文件组成就简简单单的一个html和一个csshtml部分并不是很复杂,就是一些空的div,然后加上html模板也就那么十来行代码最关键的还是css部分,也不是很多,总共一百来行但就是上面这么简简单单的两个文件可以绘画出一......