记录使用el-form的resetFields时遇到的表单数据回显失败的问题,去除nextTick解决

首先简单介绍一下resetFields的基础作用

element-plus官网el-form介绍

本案例中实现点击每行的编辑按钮时,弹出弹窗和表单

由于设置了表单校验,如图,表单内容不符合设定的校验规则时会有提示

如果仅仅这样就会出现问题,下次打开表单时,表单上还会显示红色提示字 ,对用户就很不友好,因此需要使用resetFields进行消除校验

使用先很简单,首先对el-form绑定refform="formRef"

html 复制代码
<el-form
      :model="formData"
      label-position="top"
      :rules="rules"
      ref="formRef"
      v-loading="loading"
    >
    表单内容部分
</el-form>

在自己需要的地方执行函数就行了,记得提前定义formRef

js 复制代码
const formRef=ref(null)
//自定义执行逻辑
//清空表单校验情况
  if (formRef.value) {
    formRef.value.resetFields()
  }

遇到的问题介绍

首先给大家说明一下我的函数执行逻辑

用户点击增加或编辑按钮打开对话框 - -> 调用自定义的resetForm函数重置表单数据并清空校验状态 - -> 如果用户点击的编辑按钮,回显数据到表单上

附上相关代码

js 复制代码
//点击编辑用户打开对话框
const onClickOpenEditDialog = function (row) {
  resetForm()
  //数据回显
  formData.value.birthday = row.birthday
  formData.value.name = row.name
  formData.value.citizenId = row.citizenId
  id.value = row.id
  //打开弹框
  dialogFormVisible.value = true
}

//重置表单数据
const resetForm = function () {
  formData.value = {
    citizenId: '',
    name: '',
    birthday: null
  }
  loading.value = false
  //清空表单校验情况
  nextTick(() => {
  if (formRef.value) {
    formRef.value.resetFields()
  }
})
}

重点在于,众所周知dom元素渲染需要时间,我为了防止dom还没加载出来,formRef还没绑定的时候就调用resetFields函数 ,因此添加了nextTick

遇到的问题

第一次打开编辑弹窗时,表单成功回显出该行的数据,之后无论在哪行打开弹窗,表单内容都还保留第一次打开的数据!

问题就出在刚才添加的nextTick上,由于我在执行resetForm函数后再对表单数据进行赋值,nextTick后执行的resetFields函数又重新设置值了,导致表单数据回显失败

解决方法

去掉nextTick即可,由于调用formRef的resetFields之前有添加if判断,因此就算第一次打开弹窗,ref元素还没加载成功也不会报错

相关推荐
一 乐5 分钟前
校园二手交易|基于springboot + vue校园二手交易系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端
科技D人生15 分钟前
Vue.js 学习总结(20)—— Vue-Office 实战:word、pdf、excel、ppt 多种文档的在线预览
vue.js·word·vue-pdf·stylesheet·docx-preview·vue-office
vx1_Biye_Design17 分钟前
基于Spring Boot+Vue的学生管理系统设计与实现-计算机毕业设计源码46223
java·vue.js·spring boot·spring·eclipse·tomcat·maven
vx_Biye_Design18 分钟前
基于Spring Boot+vue的湖北旅游景点门票预约平台的设计--毕设附源码29593
java·vue.js·spring boot·spring cloud·servlet·eclipse·课程设计
hedley(●'◡'●)18 分钟前
基于cesium和vue的大疆司空模仿程序
前端·javascript·vue.js·python·typescript·无人机
qq5_81151751520 分钟前
web城乡居民基本医疗信息管理系统信息管理系统源码-SpringBoot后端+Vue前端+MySQL【可直接运行】
前端·vue.js·spring boot
百思可瑞教育21 分钟前
构建自己的Vue UI组件库:从设计到发布
前端·javascript·vue.js·ui·百思可瑞教育·北京百思教育
百锦再21 分钟前
Vue高阶知识:利用 defineModel 特性开发搜索组件组合
前端·vue.js·学习·flutter·typescript·前端框架
hdsoft_huge23 分钟前
1panel面板中部署SpringBoot和Vue前后端分离系统 【图文教程】
vue.js·spring boot·后端
CappuccinoRose1 小时前
JavaScript 学习文档(二)
前端·javascript·学习·数据类型·运算符·箭头函数·变量声明