問題描述: 使用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(); }