问题背景
vue-element-ui 中 form中有个清空表单的方法,即假如给表单一个ref='form'
, 则清空表单的方法为this.$refs['form'].resetFields()
可当我在dialog组件中用这个方法的时候,这就出现问题了,居然清空不了~~~~~
问题所在
问题的本质是因为你编辑时,第一次打开dialog的时候给表单绑定的form赋值了,这时候这个form的初始值就变成了你所赋值的值,所以resetFields的时候,会将form对应的每个值重置到初始值,这时候的初始值就是你编辑时赋值的那个值, 而不是在data里声明的初始值,
如表单绑定的值为:
form: {
age: 0,
name: ''
}
但在你打开dialog编辑的时候,你又对它进行赋值,如
this.form = {
age:23,
name:"lala"
}
这个时候form表单会默认这个新赋的值为初始值
解决
解决方式是,等dialog已经初始化之后再给form赋值,也就是
this.$nextTick(() => { // 这里开始赋值 this.form.xxx = xxx; })