element-ui resetFields 无效的问题

Posted 鲸鱼只想睡觉

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了element-ui resetFields 无效的问题相关的知识,希望对你有一定的参考价值。

1.问题

触发bug的条件是先打开,编辑进行赋值,后打开新增

先点开编辑

 

 再打开新增

 

 

这个时候你会发现刚刚赋值过的数据还遗留在表单里面

 即使在打开  dialog  的时候执行了重置也没有效果

resetForm(formName) {
    if (this.dialogStatus === \'create\') {
      this.$nextTick(() => {
        this.$refs[formName].resetFields()
      })
    }
},

 

2.关于resetFields()方法

  1. 此方法用于将form表单的数据设置为初始值
  2. 而这个初始值是在form mounted生命周期被赋值上去的
  3. 所以,在 form mounted之前,如果给form表单赋值了,那么后面调用resetFields()都是无效的,因为form表单的初始值已经在 mounted 之前就被赋值了

3.解决办法

所以我们要在 form 表单 mounted之后再进行赋值操作这样就可以完美解决问题了
在点击编辑赋值的时候使用 “this.$nextTick” 方法即可

handleEdit(row) {
    this.dialogStatus = \'update\'
    this.dialogFormVisible = true
    this.$nextTick(() => {
        this.temp = Object.assign({}, row)
    })
    // this.temp = Object.assign({}, row)
},

 

以上是关于element-ui resetFields 无效的问题的主要内容,如果未能解决你的问题,请参考以下文章

Vue中element-ui的resetFields()方法重置表单无效问题及解决办法

element-ui 表单编辑之后再新增表单数据无法清空问题(已解决)

element-ui关于获取from表单项整个对象的方法,以及this.$refs[formName].resetFields()清除失效情况

element-ui重置表单并清除校验的方法

Vueelement-ui的resetFields()方法重置表单无效问题及解决办法

Vue el-form表单resetFields与clearValidate方法失效的三个坑