elementui解决el-dialog不清空内容的问题,el-dialog关闭时销毁子组件

简介: elementui解决el-dialog不清空内容的问题,el-dialog关闭时销毁子组件

前言


今天在使用element-ui中的el-dialog的时候遇到了个这样的问题:页面上点击添加的按钮,弹出el-dialog对话框,该对话框中有个添加表单的子组件,然后填写值进行保存,点击保存按钮之后,el-dialog框关闭。继续点击添加的按钮,el-dialog框继续弹出,但是上次填写的表单内容没有清空。


图如下:

38826460582597dff6f590023684f9ef.png

adeb5f9144f5e3acf13233eed384c8db.png

大致就是图上的意思。




实现思路


  1.    一开始我和同事想的是表单没有清空,于是我们就开始操作表单。比如点击添加按钮的时候,清空表单,发现不行;每天添加完之后,清空表单,发现不行;弹框的时候清空表单,发现还是不行!


  1.    接着想到了关闭框的时候销毁对象,查找官方文档,发现了个属性:destroy-on-close,文档中定义是:关闭时销毁 Dialog 中的元素,boolean类型,默认是flase,于是我将值改成了true,发现还是不行。


  1.    从网上查了下,有人说用v-if,我加上了,还是不行~


  1.    后来同事用了个时间戳的方式,终于给解决了。




实现代码


本来我都给前端的朋友打电话了,问这个问题怎么解决,他给了我个方案,大致是el-dialog的显示时机和子组件的展示时机一样,这种方案没有试,不知道可行不可行,我们现在用的是下面这种写法:


在子组件的写如下代码:

    <el-dialog
      title="新 增"
      :visible.sync="addDeviceDialogVisible"
      :append-to-body="true"
      top="1vh"
      width="70%"
      @destroy-on-close="true"
    >
      <addDevice
        :key="timer"
        @addDeviceResult="addDeviceResult"
        @quxiaoClickResult="quxiaoClickResult"
      ></addDevice>
    </el-dialog>


注意:重点就是:key="timer",这个关键代码。


然后在显示此el-dialog对话框的时候,给timer日期赋值,代码如下:

     addDeviceBtn(){
      this.addDeviceDialogVisible = true;
      this.timer = new Date().getTime();
    },


bug完美解决,记录记录不迷路~


目录
相关文章
|
2月前
|
前端开发
elementui解决el-dialog不清空内容的问题,el-dialog关闭时销毁子组件
elementui解决el-dialog不清空内容的问题,el-dialog关闭时销毁子组件
element el-cascader动态编辑赋值后,不回显的解决方法(整理)
element el-cascader动态编辑赋值后,不回显的解决方法(整理)
|
11月前
|
前端开发
饿了么el-dialog自定义内容以及el-dialog自定义样式
饿了么el-dialog自定义内容以及el-dialog自定义样式
306 0
Element el-button 按钮组件详解
本文目录 1. 背景 2. 按钮分类 3. 按钮样式 4. 按钮状态 5. 按钮分组 6. 按钮尺寸 7. 小结
2653 0
Element el-button 按钮组件详解
|
JavaScript API 前端开发
vue中对el-dialog宽度调整方法之一二
vue时,会用到el-dialog做为弹窗,但这个弹窗的宽度默认为50%.因项目中需要调整弹偿的宽度,需要设置其属性。 尝试过程如下: 方法1: 通过查找 el-dialog的官网api,查到其有宽度width的属性,设置其宽度比例即可 width="85%",但经设置后,发现没起任何作用。
7602 0
|
3天前
|
JavaScript API
【Element-UI】vue使用 this.$confirm区分取消与关闭,vue给this.$confirm设置多个按钮
【Element-UI】vue使用 this.$confirm区分取消与关闭,vue给this.$confirm设置多个按钮
7 0
|
2月前
|
前端开发
elementui的el-dialog组件与el-tabs同时用导致浏览器卡死的原因解决
elementui的el-dialog组件与el-tabs同时用导致浏览器卡死的原因解决
76 0
|
9月前
|
C#
C#用代码创建的Button大小为什么不对?
C#用代码创建的Button大小为什么不对?
|
10月前
|
JavaScript
Vue中使用element-ui的el-dialog对话框,实现拖拽效果(整理)
Vue中使用element-ui的el-dialog对话框,实现拖拽效果(整理)
|
JavaScript
elementUI封装 el-dialog
elementUI封装 el-dialog
elementUI封装 el-dialog