问题描述: 使用element开发个人后台系统,编辑和新增使用了同一个弹出框
<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""vue
@click="dialogFormVisible = true;resetForm('dlgForm')"
click弹出的时候$refs并无获取到dom元素致使 'resetFields' of undefined一、($nextTick dom下一次更新以后)dom
resetForm(formName) { this.$nextTick(()=>{ this.$refs[formName].resetFields(); }) },
二、(若是是第一次就点击新增就不必reset, 根据元素undefined判断)函数
if (this.$refs[formName] !== undefined) { this.$refs[formName].resetFields(); }