技术文摘
uniapp/vue里父元素设置pointer-events: none时子元素点击事件怎样生效
uniapp/vue里父元素设置pointer-events: none时子元素点击事件怎样生效
在uniapp或vue开发中,有时我们会遇到这样的需求:给父元素设置了 pointer-events: none 来禁止父元素的鼠标交互,但又希望子元素的点击事件能够正常生效。这在一些特定的交互场景中非常有用,比如当父元素作为一个容器,仅用于布局和样式展示,而不希望其干扰子元素的点击操作。
当给父元素设置 pointer-events: none 后,根据CSS的特性,子元素会继承该属性,导致子元素的点击事件也无法触发。要解决这个问题,有几种可行的方法。
一种常见的方法是在子元素上重新设置 pointer-events: auto。这样就可以覆盖父元素的 pointer-events: none 属性,使子元素能够正常响应点击事件。例如,在vue的模板中:
<template>
<div class="parent" @click="parentClick" style="pointer-events: none;">
<div class="child" @click="childClick" style="pointer-events: auto;">点击我</div>
</div>
</template>
<script>
export default {
methods: {
parentClick() {
console.log('父元素点击');
},
childClick() {
console.log('子元素点击');
}
}
};
</script>
另一种方法是使用JavaScript来动态控制 pointer-events 属性。可以在需要的时候,通过操作DOM元素的 style 属性来改变子元素的 pointer-events 值。
还可以考虑调整HTML结构,将子元素移出具有 pointer-events: none 属性的父元素之外,通过合理的布局和定位来实现相同的视觉效果,同时保证子元素的点击事件不受影响。
在实际开发中,我们需要根据具体的场景和需求来选择合适的解决方案。如果只是简单的单个子元素需要恢复点击事件,直接在子元素上设置 pointer-events: auto 可能是最方便的方法。而如果涉及到多个子元素或者需要动态控制,使用JavaScript来操作可能更为灵活。通过合理的运用CSS和JavaScript,我们可以在父元素设置 pointer-events: none 的情况下,让子元素的点击事件正常生效,实现丰富多样的交互效果。
TAGS: UniApp Vue 子元素点击事件 pointer-events
- K8s 放弃 Docker,Containerd 命令启用
- Spring Cloud Alibaba Nacos 服务注册及发现功能的实现
- Python 编写用户友好应用程序的三个 UI 框架
- 深度剖析 Mybatis 的架构原理及六大核心流程
- 进程间通信的加锁之法:冷门知识
- 2022 年美国技术人员薪资报告:平均年薪逾 10 万美元
- 生产环境中 Go 程序内存泄露,借助 Pprof 怎样快速定位
- 从官网入手学习 ASP.NET Core 6.0 读取配置文件
- 这破玩意儿也算高可用?
- 4 张图与 9 个维度:确保 RocketMQ 不丢消息的方法
- 12 个必知的 Vue UI 组件库,快来查收!
- Python 桑基图的惊艳绘制,你掌握了吗?
- 学会 ZooKeeper 核心的一篇文章
- Spring 于 IDEA 中的完美开工导入
- 谷歌与 OpenMined 合作 为 Python 开发者推出差分隐私工具