解决el-form、el-dialog、数据回显同时用时,重置失效问题

  • 无问题操作: 第一次打开网页,先点击新增按钮 -> dialog出现 ->
    el-form组件第一次挂载(关联的formData对象的属性的值为空字符串)el-form组件内绑定了初始值空字符串,所以后续调用resetFields的时候,它可以用到空字符串初始值来重置
  • 有问题: 第一次打开网页,先点击修改按钮 -> 虽然dialog变量为true了但是同步代码把formData对象里赋值了(默认值) ->DON更新异步 -> dialog出现 ->el-form组件第一次挂载(使用formData内置做数据回显然后第一次el-fonm内绑定了初始值(有值)) ->以后做重置,它就用绑定的默认值做重置

先调用修改回显再调用新增 this.$ref['form'] .resetFields()无法重置表单项

数据回显(Data Echoing)指的是将数据重新显示在用户界面上的过程,通常用于在用户提交表单后,或从服务器获取数据后,将数据填充回表单或展示在页面上。

element-ui的官方文档:调用编辑的时候,表单的初始值被设置为回显的值,每次重置时只是重置为初始值,不是空值。

原因:

  1. vue数据改变(先执行同步代码)再去更新DOM(异步更新)
  2. 当我们第一次打开Dialog,紧接着设置数据回显,因为Dialog还没执行完毕,这时form的初始值会被设置为回显的值,所以在调用this.$ref['form'] .resetFields()时form看起来没有重置。

解决办法:

在设置回显值的时候,不要直接赋值,在外边加上setTimeout或者this.$nextTick

javascript 复制代码
dialogVisible(row){
	// 打开弹框,这个必须写在数据回显之前,不然仍然失效
	this.configDialogVisible = true
	
	// 表单需要渲染完成后再重置
	this.$nextTick(() => {
		this.formData= JSON.parse(JSON.stringify(row));
	})
}

拓展:

其他原因:

1.表单上没有添加ref属性

解决:在form上添加ref,需要与this.$ref['form'] 中名称一致

2.el-form-item没有添加prop属性

解决:prop属性需要与data绑定的属性一致

3.this.$nextTick 的主要作用是确保在下一次 DOM 更新周期之后执行指定的回调函数,从而避免操作未更新的 DOM 元素。因为 Vue.js 是异步更新 DOM 的,有时候我们需要在数据改变并且 DOM 完成更新之后执行某些操作,这时候就可以使用 nextTick 。

相关推荐
mCell10 分钟前
【短文】不是最强,是最适合
前端·aigc·deepseek
余瑜鱼鱼鱼1 小时前
HTML常用标签总结
前端·html
Jave21081 小时前
Vue 中 mixins 混合开发的主要使用场景有哪些?
前端·vue.js
徐同保1 小时前
openclaw安装
前端
JEECG低代码平台2 小时前
JeecgBoot低代码平台 Ant Design Vue 4.x 升级避坑指南
前端·vue.js·低代码
yashuk2 小时前
Go-Gin Web 框架完整教程
前端·golang·gin
唐叔在学习2 小时前
e.preventDefault()到底怎么用?
前端·javascript
北寻北爱2 小时前
面试题-vue篇
前端·vue.js
XPoet2 小时前
AI 编程工程化:Skill——给你的 AI 员工装上技能包
前端·后端·ai编程
JEECG低代码平台2 小时前
JeecgBoot低代码平台 Qiankun 微前端集成指南:主应用配置全流程
前端·低代码