ElementUI 对话框el-dialog嵌套问题

ElementUI 官网对el-dialog内嵌问题提供的样例程序如下:

<el-dialog v-model="outerVisible" title="Outer Dialog">
  <template #default>
    <el-dialog
      v-model="innerVisible"
      width="30%"
      title="Inner Dialog"
      append-to-body
    >
    </el-dialog>
  </template>
</el-dialog>

经过本地测试运行后主要存在两个问题

  1. el-dialog父组件无法正常显示
    去掉<template></template>标签,并将v-model属性修改为:visible,父组件正常显示
<el-dialog v-model="outerVisible" title="Outer Dialog">
	<!--修改v-model为:visible并去除<template>标签-->
    <el-dialog
      :visible="innerVisible" 
      width="30%"
      title="Inner Dialog"
      append-to-body
    >
    </el-dialog>
</el-dialog>
  1. el-dialog子组件无法正常关闭
    增加:before-close属性,在点击关闭按钮时同时将子组件置为不可见
<el-dialog v-model="outerVisible" title="Outer Dialog">
	<!--修改v-model为:visible并去除<template>标签-->
    <el-dialog
      :visible="innerVisible" 
      width="30%"
      title="Inner Dialog"
      append-to-body
      :before-close="handleClose"
    >
    </el-dialog>
</el-dialog>
.......
handleClose(){
	this.innerVisible=false;
}
Element UI是一基于Vue.js的组件库,其中el-dialog是其中的一个组件,用于实现弹窗对话框的功能。下面是关于el-dialog的使用介绍: 1. 引入Element UI库:在Vue项目中,首先需要引入Element UI库。可以通过npm安装,然后在项目的入口文件中引入Element UI的样式和组件。 2. 使用el-dialog组件:在需要使用弹窗对话框的地方,可以使用el-dialog组件进行布局和交互。以下是el-dialog的基本用法: ```html <template> <div> <el-button @click="showDialog">打开对话框</el-button> <el-dialog :visible.sync="dialogVisible" title="对话框标题"> <p>对话框内容</p> <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> </div> </template> <script> export default { data() { return { dialogVisible: false }; }, methods: { showDialog() { this.dialogVisible = true; } } }; </script> ``` 在上述代码中,通过点击按钮打开对话框,使用`:visible.sync`绑定`dialogVisible`变量控制对话框的显示与隐藏。`title`属性设置对话框的标题,`slot="footer"`用于自定义对话框的底部按钮。 3. 自定义对话框内容:可以在el-dialog组件内部编写自定义的对话框内容,可以是文本、表单、图片等任意HTML元素。 4. 更多配置选项:el-dialog还提供了一些其他的配置选项,如`width`设置对话框的宽度,`modal`设置是否显示遮罩层等。可以根据实际需求进行配置。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值