解决vue多层弹框时存在遮挡问题

本文给大家介绍vue多层弹框时存在遮挡问题,解决思路首先想到的是找到对应的遮挡层的css标签,然后修改z-index值,但是本思路只能解决首次问题,再次打开还会存在相同的问题,故该思路错误,下面给大家带来一种正确的思路,一起看看吧

 

问题: 

如上图所示,当存在多层弹框时,点击黄色弹框中红色内容,弹出蓝色弹框时,出现上述情况,即表现出顶层弹框被遮挡的现象,当我们点击蓝色弹框时又会出现遮挡消失的情况,下面将对这一问题提出相应的解决办法。

解决方案:

本人解决思路,首先想到的是找到对应的遮挡层的css标签,然后修改z-index值,从而解决不同弹框遮挡层在页面的z-index的不同,但是本思路只能解决首次问题,再次打开还会存在相同的问题,故该思路错误

正确思路:

查看组件中不同属性的作用,我使用的蓝色弹框是使用的element组件中的dialog组件,故此,通过查找该组件中的属性,发现以下三个属性跟遮挡层有关

  遮挡层是必须要使用的,故此排除modal,可以通过在dialog弹框中添加modal-append-to-body或者append-to-body来测试是否能解决以上问题,如果是单层遮挡的话,使用第一个,多层遮挡的话,添加第二个,内部原因还未了解清楚,如有人了解相关问题,欢迎指导。

<el-dialog
  title="提示"
  append-to-body  
  :visible.sync="dialogVisible"
  width="30%"
  :before-close="handleClose">
  <span>这是一段信息</span>
  <span slot="footer" class="dialog-footer">
    <el-button @click="dialogVisible = false">取 消</el-button>
    <el-button type="primary" @click="dialogVisible = false">确 定</el-button>
  </span>
</el-dialog>

相关推荐

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-15 07:40:03       66 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-15 07:40:03       70 阅读
  3. 在Django里面运行非项目文件

    2024-07-15 07:40:03       57 阅读
  4. Python语言-面向对象

    2024-07-15 07:40:03       68 阅读

热门阅读

  1. Vue2-案例tab切换栏高亮

    2024-07-15 07:40:03       25 阅读
  2. 项目管理·沟通管理

    2024-07-15 07:40:03       26 阅读
  3. CentOS Stream 卸载 Podman 并安装 Docker 的方法

    2024-07-15 07:40:03       21 阅读
  4. 关于 LayoutInflater.inflate 的取值结论

    2024-07-15 07:40:03       21 阅读
  5. Zynq7000系列FPGA中的DMA控制器的编程限制

    2024-07-15 07:40:03       19 阅读
  6. [Spring Boot]定时任务因系统时间修改之后无法执行

    2024-07-15 07:40:03       19 阅读