博客
关于我
(转)CSS3之pointer-events(屏蔽鼠标事件)属性说明
阅读量:797 次
发布时间:2023-04-04

本文共 940 字,大约阅读时间需要 3 分钟。

解决绝对定位元素遮挡后鼠标事件处理问题的方法

一、pointer-events 属性介绍

1. 属性值说明

pointer-events 是 CSS3 中新增的一个属性,其支持的值大多与 SVG 有关,但对我们常规 Web 开发来说,主要关注的两个值是 noneauto

1.1 auto

默认情况下,当未指定 pointer-events 属性时,元素会继承 default behavior。这种情况下,元素会成为鼠标事件的目标,能够正常处理事件。

1.2 none

设置 pointer-events: none 后,该元素将永远不会成为鼠标事件的目标。然而,这种情况并不意味着该元素上的事件侦听器永远不会被触发。如果该元素的后代元素明确指定了 pointer-events 属性并允许其成为事件目标,那么指向该元素的事件在传播过程中会通过父元素,进而触发后代元素的事件侦听器。需要注意的是,位于屏幕上方的父元素和下方的后代元素之间的区域,鼠标活动不会同时捕获父元素和后代元素(除非父元素的 pointer-events 属性允许后代元素处理事件)。

2. 浏览器兼容情况

2.1 桌面浏览器

  • IE: 11+(IE6-10 不支持)
  • Firefox: 3.6+
  • Chrome: 4.0+
  • Safari: 6.0+
  • Opera: 15.0+

2.2 移动设备浏览器

  • iOS Safari: 6.0+
  • Android Browser: 2.1+
  • Android Chrome: 18.0+

二、使用样例

1. 使链接无法点击

通过设置 pointer-events: none 可以实现以下效果: - 链接无法被点击 - 没有鼠标手形效果(悬停效果也会消失) 这种方法可以避免按钮重复点击、表单重复提交等问题。

可以点击的链接         不能点击的链接

2. 让鼠标点击穿透上方的 div

场景描述: - 黄色半透明的 div 使用绝对定位覆盖在下方链接上方。 - 默认情况下,黄色区域下方的链接无法被点击。 - 通过设置 pointer-events: none 可以让鼠标事件穿透黄色 div,仍然可以点击下方链接。

航歌         hangge.com

转载地址:http://lnrfk.baihongyu.com/

你可能感兴趣的文章
MySQL-索引的分类(聚簇索引、二级索引、联合索引)
查看>>
Mysql-触发器及创建触发器失败原因
查看>>
MySQL-连接
查看>>
mysql-递归查询(二)
查看>>
MySQL5.1安装
查看>>
mysql5.5和5.6版本间的坑
查看>>
mysql5.5最简安装教程
查看>>
mysql5.6 TIME,DATETIME,TIMESTAMP
查看>>
mysql5.6.21重置数据库的root密码
查看>>
Mysql5.6主从复制-基于binlog
查看>>
MySQL5.6忘记root密码(win平台)
查看>>
MySQL5.6的Linux安装shell脚本之二进制安装(一)
查看>>
MySQL5.6的zip包安装教程
查看>>
mysql5.7 for windows_MySQL 5.7 for Windows 解压缩版配置安装
查看>>
Webpack 基本环境搭建
查看>>
mysql5.7 安装版 表不能输入汉字解决方案
查看>>
MySQL5.7.18主从复制搭建(一主一从)
查看>>
MySQL5.7.19-win64安装启动
查看>>
mysql5.7.19安装图解_mysql5.7.19 winx64解压缩版安装配置教程
查看>>
MySQL5.7.37windows解压版的安装使用
查看>>