vue2表单校验:添加自定义el-form表单校验规则

2024-08-28 13:20

本文主要是介绍vue2表单校验:添加自定义el-form表单校验规则,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言

在vue2表单校验:el-form表单绑定数组并使用rules进行校验_vue2 rules校验-CSDN博客中,使用form原生的rules对表单中每个控件的必填、格式等做了校验。但是保存时,除了验证每一个控件的输入合乎要求外,还需要验证控件之间的数据合规性,针对这个案例,就是其中的人员是否重复(本文代码接上文)。

需求

  1. 需要用户填写一系列人员,不设上限,但是至少填写一个。
  2. 每个人员信息包含人员名称和电话号码
  3. 希望页面“人员”前面添加必填项标识
  4. 希望检查人员姓名和手机号码是否填写,格式是否符合规范,并给出合理提示
  5. 所添加的人员不能重复,即姓名和手机号不能都相同。

解决方案

要验证人员是否重复,可以一边输入一遍检查,也可以在保存的时候一次性检查。我选择在保存时检查。

1、在数组校验信息中,添加自定义的校验方法

其中的自定义函数checkPeople,来自定义检查规则。

rules:{people:[{                validator: (rule, value, callback)=>{this.checkPeople(rule, value, callback)  //自定义校验方法},//message: '请添加人员',trigger: 'blur',required: true}],
}

2、methods中自定义检查函数

checkPeople(rule, values, callback){            //自定义验证的逻辑if(!values || values === undefined || values === null || values.length === 0){return callback(new Error(`请添加人员`));}else{//判断重复项for (let i = 0; i < this.frm.people.length; i++) {for (let j = 0; j < i; j++) {if (this.frm.people[j].nickName === this.frm.people[i].nickName &&this.frm.people[j].phonenumber === this.frm.people[i].phonenumber) {                    return callback(new Error(`第 ${i + 1} 项人员"${this.frm.people[i].nickName}"重复添加`));}}}return callback()}}

3、保存时,如往常一样使用validate

onSave(){this.$refs.frm.validate(valid => {if (valid) {                //校验通过,这里写保存逻辑}});            
},

总结

如果默认检查项无法满足需要,可以自定义validator方法,在rules中定义即可。其中,rules中不写message字段,将使用自定义validator函数中的error msg,否则,rules中的message将覆盖自定义方法中的msg:

people:[{            validator: (rule, value, callback)=>{this.checkPeople(rule, value, callback)}, message: '我是rules中的msg,将覆盖checkPeople返回的error msg',           trigger: 'blur',required: true}],

这篇关于vue2表单校验:添加自定义el-form表单校验规则的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1114877

相关文章

使用Sentinel自定义返回和实现区分来源方式

《使用Sentinel自定义返回和实现区分来源方式》:本文主要介绍使用Sentinel自定义返回和实现区分来源方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Sentinel自定义返回和实现区分来源1. 自定义错误返回2. 实现区分来源总结Sentinel自定

Java进行文件格式校验的方案详解

《Java进行文件格式校验的方案详解》这篇文章主要为大家详细介绍了Java中进行文件格式校验的相关方案,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、背景异常现象原因排查用户的无心之过二、解决方案Magandroidic Number判断主流检测库对比Tika的使用区分zip

Vue中组件之间传值的六种方式(完整版)

《Vue中组件之间传值的六种方式(完整版)》组件是vue.js最强大的功能之一,而组件实例的作用域是相互独立的,这就意味着不同组件之间的数据无法相互引用,针对不同的使用场景,如何选择行之有效的通信方式... 目录前言方法一、props/$emit1.父组件向子组件传值2.子组件向父组件传值(通过事件形式)方

如何自定义Nginx JSON日志格式配置

《如何自定义NginxJSON日志格式配置》Nginx作为最流行的Web服务器之一,其灵活的日志配置能力允许我们根据需求定制日志格式,本文将详细介绍如何配置Nginx以JSON格式记录访问日志,这种... 目录前言为什么选择jsON格式日志?配置步骤详解1. 安装Nginx服务2. 自定义JSON日志格式各

css中的 vertical-align与line-height作用详解

《css中的vertical-align与line-height作用详解》:本文主要介绍了CSS中的`vertical-align`和`line-height`属性,包括它们的作用、适用元素、属性值、常见使用场景、常见问题及解决方案,详细内容请阅读本文,希望能对你有所帮助... 目录vertical-ali

Android自定义Scrollbar的两种实现方式

《Android自定义Scrollbar的两种实现方式》本文介绍两种实现自定义滚动条的方法,分别通过ItemDecoration方案和独立View方案实现滚动条定制化,文章通过代码示例讲解的非常详细,... 目录方案一:ItemDecoration实现(推荐用于RecyclerView)实现原理完整代码实现

Python实现自动化表单填写功能

《Python实现自动化表单填写功能》在Python中,自动化表单填写可以通过多种库和工具实现,本文将详细介绍常用的自动化表单处理工具,并对它们进行横向比较,可根据需求选择合适的工具,感兴趣的小伙伴跟... 目录1. Selenium简介适用场景示例代码优点缺点2. Playwright简介适用场景示例代码

浅析CSS 中z - index属性的作用及在什么情况下会失效

《浅析CSS中z-index属性的作用及在什么情况下会失效》z-index属性用于控制元素的堆叠顺序,值越大,元素越显示在上层,它需要元素具有定位属性(如relative、absolute、fi... 目录1. z-index 属性的作用2. z-index 失效的情况2.1 元素没有定位属性2.2 元素处

Python实现html转png的完美方案介绍

《Python实现html转png的完美方案介绍》这篇文章主要为大家详细介绍了如何使用Python实现html转png功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 1.增强稳定性与错误处理建议使用三层异常捕获结构:try: with sync_playwright(

基于Spring实现自定义错误信息返回详解

《基于Spring实现自定义错误信息返回详解》这篇文章主要为大家详细介绍了如何基于Spring实现自定义错误信息返回效果,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录背景目标实现产出背景Spring 提供了 @RestConChina编程trollerAdvice 用来实现 HTT