elementui表单的验证问题

2023-09-21 18:00:06

elementui表单的验证问题

element ui是基于vue的一个ui框架,用起来还是挺不错的,但是有时候还是会遇到一些摸不着头脑的情况。

​ 我在打开一个新增数据的对话框的时候出现了一个问题,明明是新增,但是一打开就出现了错误提示,这肯定是不对的,用户体验也是极其不好的。到底是什么原因导致的呢?

在这里插入图片描述

​ 经过我的检查,发现主要原因就是我的新增和修改的对话框是用的同一个,而显示错误提示的都是trigger类型为change的。

​ 具体原因就是因为新增和修改要操作的字段都是一摸一样的,我肯定也不会去写两套代码了呀,通过一些变量我就能区分。但是这就导致了如果我刚刚进入页面的时候,如果第一次点击的是修改按钮,弹出的是修改对话框,那么我会从数据库里拿数据进行数据展示,会将表单的数据初始化一次。那么我第二次点击的按钮是新增按钮时,我肯定会把表单的数据全部置空,从而触发change事件,然后触发表单校验。

​ 部分代码如下:

data() {
      return {
        formData: {"groupType": null}, // 表单数据,最开始为null
        formVisible: false // 表单是否显示,
		rules: {groupType: [{ required: true, message: '请输入分组类型', trigger: 'change' }]} // 配置表单验证,在页面上“分组类型”其实是一个下拉选择框
     }
},
created() {
	// 	进行一些初始化
},
methods: {
	showUpdateDialog: function () {
		// 加载数据
		this.$http.get(...).then(
			response => {
				// 做一些数据处理
				...
				// 显示对话框
				this.formVisible = true;
			},
        	response => console.log(response)
		);
	},
	showCreateDialog: function () {
		this.$refs['form'].resetFields();
		...
	}
}

​ 然后我在网上搜了一下解决办法,大部分都是说用this.$refs[‘form’].resetFields()重置一下就行,我试了但是不行,然后我去看了一下官方文档,重置是重置了,但是是重置为初始值,但是我仔细去研究了一下这个初始值,其实就是第一次给form表单赋值时,它在页面上渲染出来的值。对应上我的操作流程,其实就是我第一次打开修改对话框时,从数据库里拿到的数据,只能说是白给。

在这里插入图片描述

​ 虽然白给了,但没有完全白给,官方的这段话其实已经给了答案,稍微调整一下代码。在调用showUpdateDialog方法打开修改对话框时,先直接把对话框显示出来,因为formData中分组类型的初始值是为null,这个时候表单就会渲染,那么下次用resetFields方法重置时,就能帮我重置回null。

​ 部分代码如下:

data() {
      return {
        formData: {"groupType": null}, // 表单数据,最开始为null
        formVisible: false // 表单是否显示,
		rules: {groupType: [{ required: true, message: '请输入分组类型', trigger: 'change' }]} // 配置表单验证,在页面上“分组类型”其实是一个下拉选择框
     }
},
created() {
	// 	进行一些初始化
},
methods: {
	showUpdateDialog: function () {
		// 显示对话框
		this.formVisible = true;
		// 加载数据
		this.$http.get(...).then(
			response => {
				// 做一些数据处理
				...
			},
        	response => console.log(response)
		);
	},
	showCreateDialog: function () {
		this.$refs['form'].resetFields();
		...
	}
}

​ 虽然已经能解决这个问题了,但是还是有一个问题,如果用户使用的时候正好网络不好,但是修改对话框已经打开了,以前的数据还没有加载出来,如果这时候用户胡乱操作很容易造成异常,所以还是等拿到数据后再打开对话框最好。

​ 再次调整代码:

data() {
      return {
        formData: {"groupType": null}, // 表单数据,最开始为null
        formVisible: true // 表单直接显示,
		rules: {groupType: [{ required: true, message: '请输入分组类型', trigger: 'change' }]} // 配置表单验证,在页面上“分组类型”其实是一个下拉选择框
     }
},
mounted(){
	// 隐藏表单
	this.dialogFormVisible = false;
},
created() {
	// 	进行一些初始化
},
methods: {
	showUpdateDialog: function () {
		// 加载数据
		this.$http.get(...).then(
			response => {
				// 做一些数据处理
				...
				// 显示对话框
				this.formVisible = true;
			},
        	response => console.log(response)
		);
	},
	showCreateDialog: function () {
		this.$refs['form'].resetFields();
		...
	}
}

​ 在初始值设置的时候,就直接把formVisible设置为true,把表单渲染出来,而此时groupType为null,然后在mounted钩子函数中隐藏表单,这样在用户的感知中,表单一直没有显示过,但其实表单数据的初始化已经完成了。这里为什么用mounted而不是在created里做这个事呢,先看看两者的区别:

​ 在Vue中,created和mounted是两个生命周期钩子函数。

​ created钩子函数在Vue实例创建完成后立即调用,此时模板和虚拟DOM都未渲染成真实的DOM。在这个阶段,可以进行一些初始化操作,如数据的获取、事件的监听等。

​ mounted钩子函数在Vue实例挂载到真实DOM后调用,此时模板和虚拟DOM已经渲染成真实的DOM。在这个阶段,可以进行一些需要操作DOM的操作,如获取DOM元素、操作DOM等。

​ 总的来说,created适合进行数据的初始化和事件的监听等操作,而mounted适合进行DOM操作和一些需要等待DOM渲染后才能进行的操作。


​ 至此,问题彻底解决。

更多推荐

spring-boot---validation,参数校验,分组,嵌套,各种类型

写在前面:参数校验基本上是controller必做的事情,毕竟前端传过来的一切都不可信。但是每次if(StrUtil.isNotNull())啥的有时候多还难写。validation可以简化这一操作。文章目录项目构建问题展示validation使用快速入门注释Valid与Validated区别使用范围分组嵌套验证项目构

基于微信小程序的实验室预约管理系统设计与实现

前言💗博主介绍:✌全网粉丝10W+,CSDN特邀作者、博客专家、CSDN新星计划导师、全栈领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战✌💗👇🏻精彩专栏推荐订阅👇🏻2023-2024年最值得选的微信小程序毕业设计选题大全:100个热门选

python/C++二分查找库函数(lower_bound() 、upper_bound,bisect_left,bisect_right)

二分查找是一种经典的搜索算法,广泛应用于有序数据集中。它允许在大型数据集中高效地查找目标元素,减少了搜索的时间复杂度。本文将介绍在C++和Python中内置的二分查找函数,让二分查找变得更加容易。c++lower_bound()、upper_bound定义在<algorithm>头文件中,lower_bound和upp

大数据分布式处理框架Hadoop

大数据是什么大数据容量常以TB、PB、甚至EB为单位,远超传统数据库的承载能力,无论入库还是查询都出现性能瓶颈。Hadoop是什么Hadoop是开源的分布式计算技术框架,用于处理大规模数据和实现分布式存储。Hadoop核心组件HDFS(HadoopDistributedFileSystem分布式文件系统):是Hadoo

学习Nano编辑器:入门指南、安装步骤、基本操作和高级功能

文章目录使用Nano编辑器入门指南引言1.1关于Nano编辑器1.2Nano的起源和特点安装Nano2.1在Debian/Ubuntu系统上安装Nano2.2在CentOS/RHEL系统上安装Nano2.3在其他Linux发行版上安装Nano启动Nano3.1命令行启动Nano3.2打开文件Nano的基本操作4.1光标

如何批量为文件夹命名

如果你想要命名一些这样名字具有规律性的文件夹,当文件的数量增多,一个一个命名是非常耗费时间的。很容易想到,如果使用EXCEL,只需往下拉,就能很轻松的拉出1到5。那么,我们如何利用EXCEL来对文件夹进行快速的批量命名呢?以上图为例子,人名可能是我们已知的,可以从表格直接复制过来。而客户名1到客户名5,我们可以直接使用

大数据Flink(六十四):Flink运行时架构介绍

文章目录Flink运行时架构介绍一、系统架构二、​​​​​​​​​​​​​​整体构成三、作业管理器(JobManager)四、任务管理器(TaskManager)Flink运行时架构介绍我们已经对Flink的主要特性和部署提交有了基本的了解,那它的内部又是怎样工作的,集群配置设置的一些参数又到底有什么含义呢?接下来我们

基于vue的黑马前端项目小兔鲜

目录项目学习初始化项目建立项目引入elementpluselementPlus主题设置配置axios路由引入静态资源自动导入scss变量Layout页组件结构快速搭建字体图标渲染一级导航渲染吸顶导航交互实现Pinia优化重复请求Home页分类实现banner轮播图新鲜好物实现人气推荐实现懒加载指令实现产品列表实现Goo

正确设置PyTorch训练时使用的GPU资源

背景:最近在使用HuggingFace的transformersapi来进行预训练大模型的微调,机器是8卡的GPU,当我调用trainer.train()之后,发现8个GPU都被使用了,因为这个机器上面还有其他人跑的模型,当我进行训练的时候,GPU的使用率就接近了100%,这样导致其他人的模型响应速度特别的慢,因为他们

微信小程序如何刷新当前页面

微信小程序是一种快速发展的移动应用程序开发平台,它提供了许多功能和特性,使开发者能够轻松创建功能丰富的小程序。在开发小程序时,有时我们需要刷新当前页面来更新数据或重新加载页面内容。本文将解释如何在微信小程序中刷新当前页面的代码。引言微信小程序的流行使得越来越多的开发者将其作为构建移动应用的首选平台。然而,与传统的网页开

快速了解Apipost

随着数字化转型的加速,API(应用程序接口)已经成为企业间沟通和数据交换的关键。而在API开发和管理过程中,API文档、调试、Mock和测试的协作显得尤为重要。Apipost正是这样一款一体化协作平台,旨在解决这些问题,提高API开发效率和质量。Apipost提供API文档管理功能,让后端开发人员可以在开发完接口调试的

热文推荐