el-dialog嵌套,关闭第二个el-dialog,第一个el-dialog的按钮点击不了
时间: 2024-02-22 17:52:56 浏览: 674
根据提供的引用内容,el-dialog嵌套时,如果关闭第二个el-dialog,可能会导致第一个el-dialog的按钮无法点击。这是因为第二个el-dialog被关闭后,遮罩层仍然存在,导致无法点击第一个el-dialog的按钮。
解决这个问题的方法是给第二个el-dialog添加append-to-body属性,并将其设置为true。这样,第二个el-dialog会插入到body元素上,保证了内外层el-dialog和遮罩层级关系的正确。
另外,也可以考虑使用el-dialog和ElMessageBox结合的形式,这样就不会出现弹窗被遮住的问题。
以下是一个示例代码,演示了el-dialog嵌套时关闭第二个el-dialog后,第一个el-dialog的按钮可以正常点击:
```html
<template>
<div>
<el-dialog
title="第一个el-dialog"
:visible.sync="dialogVisible1"
width="30%"
>
<p>第一个el-dialog的内容</p>
<el-button type="primary" @click="openDialog2">打开第二个el-dialog</el-button>
</el-dialog>
<el-dialog
title="第二个el-dialog"
:visible.sync="dialogVisible2"
width="30%"
:append-to-body="true"
>
<p>第二个el-dialog的内容</p>
<el-button type="primary" @click="closeDialog2">关闭第二个el-dialog</el-button>
</el-dialog>
</div>
</template>
<script>
export default {
data() {
return {
dialogVisible1: false,
dialogVisible2: false
};
},
methods: {
openDialog2() {
this.dialogVisible2 = true;
},
closeDialog2() {
this.dialogVisible2 = false;
}
}
};
</script>
```
阅读全文