解决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 。

相关推荐
狗哥哥7 分钟前
微前端路由设计方案 & 子应用管理保活
前端·架构
TT哇31 分钟前
【实习 】银行经理端两个核心功能的开发与修复(银行经理绑定逻辑修复和线下领取扫码功能开发)
java·vue.js
前端大卫42 分钟前
Vue3 + Element-Plus 自定义虚拟表格滚动实现方案【附源码】
前端
却尘1 小时前
Next.js 请求最佳实践 - vercel 2026一月发布指南
前端·react.js·next.js
ccnocare1 小时前
浅浅看一下设计模式
前端
Lee川1 小时前
🎬 从标签到屏幕:揭秘现代网页构建与适配之道
前端·面试
Ticnix1 小时前
ECharts初始化、销毁、resize 适配组件封装(含完整封装代码)
前端·echarts
纯爱掌门人2 小时前
终焉轮回里,藏着 AI 与人类的答案
前端·人工智能·aigc
twl2 小时前
OpenClaw 深度技术解析
前端
崔庆才丨静觅2 小时前
比官方便宜一半以上!Grok API 申请及使用
前端