技术文摘
UniApp/Vue中父元素Pointer-Events: None时让子元素点击生效的方法
UniApp/Vue中父元素Pointer-Events: None时让子元素点击生效的方法
在UniApp和Vue开发中,我们有时会遇到这样的需求:给父元素设置了pointer-events: none样式后,希望子元素的点击事件仍然能够生效。这在一些特定的交互场景中非常有用,比如创建一个不可点击的遮罩层,但其中的某些按钮或链接需要可以被用户操作。下面就来介绍几种实现的方法。
方法一:使用CSS的pointer-events属性
虽然给父元素设置了pointer-events: none,但我们可以给子元素重新设置pointer-events: auto。这样,子元素就可以响应点击事件了。例如:
<template>
<div class="parent" @click="parentClick">
<div class="child" @click="childClick">点击我</div>
</div>
</template>
<style>
.parent {
pointer-events: none;
}
.child {
pointer-events: auto;
}
</style>
方法二:通过JavaScript动态设置pointer-events属性
如果需要根据某些条件来控制子元素的点击事件是否生效,可以在Vue的生命周期函数或事件处理函数中,使用JavaScript动态地修改子元素的pointer-events属性。例如:
<template>
<div class="parent" @click="parentClick">
<div class="child" ref="child" @click="childClick">点击我</div>
</div>
</template>
<script>
export default {
mounted() {
this.$refs.child.style.pointerEvents = 'auto';
},
methods: {
parentClick() {
console.log('父元素点击');
},
childClick() {
console.log('子元素点击');
}
}
};
</script>
方法三:改变DOM结构
如果以上方法都不适合你的场景,还可以考虑改变DOM结构,将子元素移出父元素的层级,或者使用其他方式来实现类似的效果,从而避免pointer-events: none对点击事件的影响。
在UniApp和Vue开发中,当父元素设置了pointer-events: none时,我们可以通过多种方法让子元素的点击事件生效,具体使用哪种方法,可以根据实际需求和项目情况来选择。
TAGS: UniApp Vue pointer-events 子元素点击生效
- GO 中编码的优雅性与圈复杂度的降低
- 【探秘】JUC 并发工具包底层机制 揭示 Unsafe 的强大之处
- UML 类图的图形表示,您掌握了吗?
- 简约风盛行,轻松驾驭命令行:proper_cli 使 CLI 开发简便易用
- JsonConvert 认识不足终遇问题
- 利用 React/Vue 构建通用表单管理配置平台
- Mybatis 自定义类型转换及数据加密解密实战指南
- 尤雨溪谈 Vite 的现状及未来
- 微软正式为 VS Code 推出 C# 开发套件
- Python 3.12 版本登场:f-string 解析优化,性能整体提升 5%
- 五分钟内借助 Initializr 快速开发 Spring Boot 应用
- Java 中定时任务调度的不准确与执行异常致使计划任务失败
- 五分钟明晰链表实现:Python 数据结构与算法
- Java 代码高重复率与高模块耦合度致使可扩展性和维护性降低
- Sentinel 原理之解析,你掌握了吗?