CSS操纵元素的禁用和启用

通常表单控件都会有属性readonly、disabled对元素进行只读、禁用等操作。

而有时候我们想要div也达到类似效果,可以用CSS样式pointer-events: none进行控制。

科普知识

CSS样式的pointer-events: none用于控制一个元素能否响应鼠标操作。当该属性设置为none时,当前元素及其子元素将无法与鼠标或触摸设备产生交互作用。鼠标点击、滑过、甚至移动都不会触发事件。

css 复制代码
.disable{
	pointer-events : none;
}

具体来说,pointer-events: none;的效果如下:

  1. 忽略鼠标操作:对一个元素设置pointer-events: none;,能让浏览器在处理鼠标操作时,忽视掉这个元素的存在,直接穿透到点击区域背后的元素上。
  2. 不会触发事件:意味着直接在这个元素上做鼠标操作时,该元素上的鼠标效果不会被处理,例如hover效果;该元素上的鼠标事件不会被响应,例如click、mousein、mousedown事件。

此外还有以下常见使用场景:

  1. 实现视差滚动效果:使滚动层无法响应交互,实现粘性效果。
  2. 实现遮罩层:可以使下层元素无法响应事件,产生遮蔽遮罩的效果。
  3. 修复点击穿透问题:在元素的子元素上设置,防止点击事件穿透到父层元素上。
  4. 改变鼠标事件的触发对象:可以在一个元素上设置pointer-events: none;,然后在它的子元素上绑定事件,这样鼠标交互会直接在子元素上触发事件,跳过中间元素。

JQuert版本设置样式控制

css 复制代码
$('div[name=××××]').css("pointer-events","none"); // 设置div禁用
$('div[name=××××]').css("pointer-events","");     // 恢复div使用

代码示例

cpp 复制代码
<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title>DIV模拟禁用</title>
		<style>
			div{
				width: 200px;
				height: 200px;
				background: pink;
			}
			.disable{
				pointer-events : none;
			}
		</style>
	</head>
	<body>
		<div class="disable" onclick="show()">
		</div>
		<script>
			function show(){
				alert("我被点击啦!");
			}
		</script>
	</body>
</html>

效果展示

div盒子未加入 pointer-events : none;可以弹框显示

div盒子加上类样式disable就无法弹框显示!

相关推荐
洗发水很好用2 分钟前
uniapp纯css实现基础多选组件
前端·css·uni-app
踩着两条虫13 分钟前
VTJ.PRO 在线应用开发平台的代码生成与模板系统
前端·低代码·ai编程
前端小崽子18 分钟前
线上复制按钮失效?也许是这个原因
前端
张元清18 分钟前
React 滚动效果:告别第三方库
前端·javascript·面试
有志20 分钟前
Vue 学习总结(Java 后端工程师视角)
前端
踩着两条虫21 分钟前
VTJ.PRO 在线应用开发平台的DSL生命周期
前端·低代码·ai编程
我是伪码农22 分钟前
JS 复习
开发语言·前端·javascript
小碗细面22 分钟前
Claude Code 很强,但为什么我越来越常打开 Codex App?
前端·chatgpt·ai编程
愿你如愿23 分钟前
React Fiber 的主要目标是什么
前端·react.js
漂移的电子28 分钟前
【echarts 细节】
前端·javascript·echarts