[已解决]Vue3+Element-plus使用el-dialog对话框无法显示

文章目录

问题发现

点击按钮,没有想要的弹框

代码如下

修改 el-dialog到body中,还是不能显示

原因分析

使用devtool中vue工具进行查看组件结构

原因在于,在一个局部组件(Detail->ElTabPane->...)中使用el-dialog,这个局部组件实际DOM结构中层级较低,限制了遮罩的扩展,el-dialog是覆盖整个页面区域的组件。

应该在更高层级来显示el-dialog,可以使用Vuex、props+emit、事件总线(Event Bus)来控制它的显示与隐藏。

解决方法

回忆原来在较高DOM层级的组件(Detail)中也有使用el-dialog,我考虑使用Vuex中的state来保存弹窗显示状态、以及弹窗内容的选择(条件渲染),这样,两个场景下的弹窗都可以共用这一个el-dialog组件

相关推荐
寰宇软件3 小时前
PHP校园助手系统小程序
小程序·vue·php·uniapp
是梦终空6 小时前
JAVA毕业设计210—基于Java+Springboot+vue3的中国历史文化街区管理系统(源代码+数据库)
java·spring boot·vue·毕业设计·课程设计·历史文化街区管理·景区管理
寰宇软件20 小时前
PHP同城配送小程序
微信小程序·vue·php·uniapp
℡52Hz★1 天前
如何正确定位前后端bug?
前端·vue.js·vue·bug
寰宇软件1 天前
PHP企业IM客服系统
微信小程序·vue·php·uniapp
Y编程小白1 天前
Vue2.0的安装
java·vue
寰宇软件2 天前
PHP教育系统小程序
小程序·uni-app·vue·php
寰宇软件2 天前
PHP装修行业小程序
小程序·uni-app·vue·php
嘿siri3 天前
html全局遮罩,通过websocket来实现实时发布公告
前端·vue.js·websocket·前端框架·vue·html
Nejosi_念旧3 天前
开发常用工具
flutter·vue·gitlab·postman