element ui 中的 resetFields() 报错'resetFields' of undefined

  每次作各类form表单时,首先要注意的是初始化,可是刚开始若没有仔细看文档,则会本身写个方法将数据设置为空,可是这样就会出现一个问题,表单内存在各类验证,假如是一个弹框内有form表单,弹框出现就执行上述代码,可能会出现表单验证的错误提示仍然保留的状况。javascript

element UI 官方文档提供了一个resetFields()的方法vue

this.$refs[formName].resetFields()

不只能够帮你初始化数据,还能够将验证提示消除!!!

可是在使用时踩了一些坑,java

编辑和新增使用了同一个弹出框<el-dialog><el-form></el-form></el-dialog>
绑定了数据data里的commentForm对象
为了在新增弹出框清空表单, 使用了this.$refs[formName].resetFields()
每次第一次点击新增显示弹出框,都会报错
"[Vue warn]: Error in event handler for "click": "TypeError: Cannot read property 'resetFields' of undefined""dom

问题缘由: mouted加载table数据之后,隐藏的弹出框并无编译渲染进dom里面。

因此@click="dialogFormVisible = true;resetForm('dlgForm')"click弹出的时候$refs并无获取到dom元素致使 'resetFields' of undefined

解决方法:

一、($nextTick dom下一次更新以后)函数

resetForm(formName) {
                this.$nextTick(()=>{ this.$refs[formName].resetFields(); }) },

二、(若是是第一次就点击新增就不必reset, 根据元素undefined判断)this

if (this.$refs[formName] !== undefined) { this.$refs[formName].resetFields(); }

注意事项:对DOM一系列的js操做最好都要放进Vue.nextTick()的回调函数中

相关文章
相关标签/搜索