elementplus如何实现dialog遮罩层外的元素可以被操作点击

elementplus如何实现dialog遮罩层外的元素可以被操作点击

element plus 组件库中的 dialog 组件可以说是使用频率最高的组件之一,它的效果是弹出一个对话框,外面默认会有一个蒙层。

现在我碰到的需求是,弹窗要正常显示,但是蒙层下面的元素内容又是可以点击的,如何实现呢?

以下是我的解决代码(vue)

首先是 HTML 部分

html 复制代码
<div class="dialog">
  <el-dialog
    v-model="visible"
    title="xxx"
    :close-on-click-modal="false"
    :close-on-press-escape="false"
  >
    <!-- content.... -->
  </el-dialog>
</div>

然后是 css 代码

html 复制代码
<style lang="scss" scoped>
.itrImgDialog {
  :deep(.el-overlay) {
    background-color: transparent;
    pointer-events: none;
  }
  :deep(.el-dialog) {
    pointer-events: auto;
  }
}
</style>

来解释一下:

要实现蒙层外面的内容可以点击被操作,核心是用到了pointer-events; 这个属性用于控制元素是否能成为鼠标事件的目标。

常见的两个值

auto:这是默认值。元素可以响应鼠标事件。

none:元素不会成为鼠标事件的目标。即鼠标事件会"穿透"这个元素,作用在元素下方的其他元素上。

所以我们把 el-overlay 设置为 pointer-events: none; ,但是为了要保证 dialog 本身能够点击,所以将 el-dialog 设置为 pointer-events: auto;

值得注意的是,el-dialog 的 mask 属性不要设置成 false,否则上述修改是不生效的,一定要注意。

希望能帮到你。

相关推荐
Eiceblue6 分钟前
C# 删除 PDF 页面:单页 / 多页批量删除技巧
前端·pdf·c#
悟空瞎说6 分钟前
从isMounted到跨页面状态:高级前端如何优雅解决订单场景的“幽灵陷阱”(附React/Vue完整代码)
前端·javascript
C_fashionCat8 分钟前
【2026面试题】前端实际场景去考察原理
前端·vue.js·面试
落魄江湖行9 分钟前
进阶篇三 Nuxt4 Nitro 引擎:Nuxt 的服务端核心
前端·vue.js·typescript·nuxt4
一壶纱11 分钟前
Element Plus 主题构建方案
前端·vue.js
程序员马晓博12 分钟前
我的大脑不下班:一个前端工程师的工作反刍自救指南
前端
吴声子夜歌13 分钟前
Vue3——表单元素绑定
前端·vue·es6
神の愛14 分钟前
js的深拷贝和浅拷贝?啥情况讲解下??底层堆栈空间??object.prototype.toString.call(),还有bind,的具体使用?
前端·javascript·原型模式
浩星15 分钟前
「React + Cesium 最佳实践」完整工程化方案
前端·vue.js·react.js
1314lay_100722 分钟前
el-table表格数据分页切片,导致表格的多选失效
javascript·vue.js·elementui