不刷新页面重新打开el-dialog时,如果我们绑定了rules或者某个值需要required,它总会自动校验。
查看了多个博文,发现常用的有两种解决方法(下列方法都可以在其他博文查看,不再细写,如有需要请自行查询):
1.给dialog套上v-if ;
2.在关闭dialog时,监听关闭回调,清除校验。
我在自己的项目里使用了上述两种方法,都不太好用,自己琢磨出了另一种方法:
调用dialog打开的回调
methods:
openDialog(){
this.$nextTick(() => {
this.$refs.dataForm.clearValidate();
})
}
初始化dialog时, 拿到变化后的dom, 进行清除校验
补充知识:Cannot read property 'resetFields' of undefined 问题及引申
问题描述:使用element开发我的后台系统,编辑和新增使用了同一个弹出框
绑定了数据data里的commentForm对象
为了在新增弹出框清空表单, 使用了this.$refs[formName].resetFields()
每次第一次点击新增显示弹出框,都会报错
"[Vue warn]: Error in event handler for "click": "TypeError: Cannot read property 'resetFields' of undefined""
问题原因&