Vue+Element-ui表单resetFields无法重置问题
问题背景
在开发中自己使用this.$refs[formName].resetFields()出现无法重置表单的的场景有两种:
1、<Modal/ >组件内表单填写,在 modal 组件未挂载在 DOM 元素中,就无法获取到 form 表单组件的实例,所以this.$refs[formName]获取实例就会出现 undefined 的情况。
2、比如编辑表格数据,需要回显表单数据,我们一般的做法就是放表单的 rawValue 赋值就搞定,但是我们从新添加数据之前想重置表单就无效。
下面说说我遇到上面两种无法重置表单问题的解决方案:
第一个无法解决重置表单解决方案
判断不是undefined的情况下才会去调用 resetFields 方法:
if (this.$refs["form"] !== undefined) { this.$refs["form"].resetFields(); }
第二个无法解决重置表单解决方案
回显填充表单数据逻辑写在nextTick函数的callback中,nextTick原理大家可自行搜索就有,不多说。
Vue2.x
fillFormData(rawValue) { this.$nextTick(() => { for (let key in this.form) { if (rawValue[key]) { this.form[key] = rawValue[key]; } } }); },
Vue3.x
import { nextTick } from 'vue'; const fillFormData = () => { nextTick(()=>{ // 数据回显逻辑 }) }
这样,在添加新的数据之前,再调用一下重置表单resetFields()就可以了。
到此这篇关于Vue+Element-ui表单resetFields无法重置问题的文章就介绍到这了,更多相关Vue Element表单resetFields无法重置内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
Vue echarts 实现离线中国地图的示例代码(细化到省份)
这篇文章主要介绍了Vue echarts 实现离线中国地图,细化到省份,本文通过示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2022-09-09vue子组件改变父组件传递的prop值通过sync实现数据双向绑定(DEMO)
本文通过一个demo给大家介绍了vue子组件改变父组件传递的prop值通过sync实现数据双向绑定,代码简单易懂,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下2020-02-02Vue项目如何根据图片url获取file对象并用axios上传
这篇文章主要介绍了Vue项目如何根据图片url获取file对象并用axios上传问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教2023-09-09vue中this.$http.post()跨域和请求参数丢失的解决
这篇文章主要介绍了vue中this.$http.post()跨域和请求参数丢失的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2022-04-04
最新评论