当前位置: 首页 > news >正文

Vue使用ElementUI对表单元素进行自定义校验

前言

在使用ElementUI的表单元素时候,除了做一些简单的非空处理校验,在一些特殊的场合,还需要我们做一些自定义校验。

其实ElementUI不仅提供了基本的非空校验,也对我们提供了自定义检验。

在使用的时候还是遇到了一些坑,下面简单的总结分享下

非空校验

知道自定义校验之前,需要知道基本的非空校验

如下图,ElementUI已经帮助我们创建好了一个简单的demo,我们直接拿来用即可。

在这里插入图片描述

这里我也是直接复制的demo,然后根据自己需求进行修改。

在这里插入图片描述

简单的说下相关的一些地方吧

一个表单包含着很多页面元素,根据自己的需求使用不同的组件去拼接即可:

在这里插入图片描述

表单的元素我们可以直接在data生成一个表单数据,把里面的属性都放在数据里面,这样可以直接把这个表单传到后台进行交互。不然一个一个传也太麻烦了

在这里插入图片描述

然后就是检验(rules),这里一般做对表单元素校验的处理

除了手机号,密码,确认密码这三项,我都是只做了最基本的非空校验。

在这里插入图片描述

我们可以注意到,每一个表单元素都有一个红色的星号,这就是必输项的一个标识,我们主要通过这个属性控制:

required: true

比如我现在把用户名的required: true去掉

在这里插入图片描述

页面上的非空校验就没了,所以不论你校验写的再好,不加这个属性就等于没用。

在这里插入图片描述

自定义校验

我主要以两个较为经典的例子举例,一个是手机号的格式,一个是密码和确认密码的判断是否相同

关于表单的自定义校验ElementUI也给了demo,就是我的第二个例子

在这里插入图片描述

大家都知道,手机号都是有一定的规则的,不是只有11位数字就是这么简单的,还要以固定格式开头等。

定义自定义校验函数

针对这种格式,我们就可以使用自定义校验了,我们可以在data中定义自定义校验:

在这里插入图片描述

可以理解成把它理解成一个变量,有着自定义的回调函数进行自定义错误提示

可以看到首先是判断输入的手机号是否为空,如果为空给出的提示是:请输入手机号码

如果输入的手机号不为空,那么就通过正则表达式判断是否合法,如果不合法的话,同样给出对应的提示信息,这便是自定义校验,根据自己的需求定义自己的规则。

 // 校验手机号是否合法var checkPhone = (rule, value, callback) => {if (value === "") {callback(new Error("请输入手机号码"))} else if (!/^(13[0-9]|14[5|7]|15[0|1|2|3|4|5|6|7|8|9]|18[0|1|2|3|5|6|7|8|9])\d{8}$/.test(value)) {callback(new Error("手机号格式有误,请输入正确的手机号码"))} else {callback()}};

使用自定义校验函数

使用起来也很简单,在原有的表单校验基础上加上validator属性,值就是定义自定义函数的变量名

注意:使用了自定义校验函数之后,就不要在这里写message提示信息了。直接在函数里面定义错误信息即可。

  phone: [ { required: true,validator: checkPhone, trigger: 'blur' }],

两次密码是否相同这个demo直接拿着ElementUI给的demo即可。这里不再赘述

总结

通过表单自定义校验,大大提高了灵活性和可控性。个人还是比较喜欢的

http://www.lryc.cn/news/15809.html

相关文章:

  • linux的文件权限介绍
  • 支付系统中的设计模式03:模板方法模式
  • 【黏住用户的不是小红书,而是它背后的那些人】
  • 基于STM32采用CS创世 SD NAND(贴片SD卡)完成FATFS文件系统移植与测试(中篇)
  • 0基础学插画是报班还是自学
  • 【Spring Cloud Alibaba】000-Spring Cloud Alibaba 问题集锦[持续更新]
  • Java使用MD5加盐对密码进行加密处理,附注册和登录加密解密处理
  • vue3组件篇 Select
  • 华为OD机试 - 员工出勤(Python) | 机试题+算法思路+考点+代码解析 【2023】
  • 力扣:27. 移除元素
  • 华为OD机试 - 剩余可用字符集(Python) | 机试题+算法思路+考点+代码解析 【2023】
  • 金三银四丨黑蛋老师带你剖析-安全开发岗
  • isNaN、Number.isNaN、isFinite、Number.isFinite
  • MyBatis分页插件
  • Vue组件间通信的四种方式(函数回调,自定义事件,事件总线,消息订阅与发布)
  • 华为OD机试真题Python实现【求字符串中所有整数的最小和】真题+解题思路+代码(20222023)
  • 行为型设计模式之中介者模式
  • JDK8增加的特性
  • 华为OD机试 - 求数组中最大n个数和最小n个数的和(Python) | 机试题+算法思路+考点+代码解析 【2023】
  • 如何写出更加契合浙大MBA项目提面申请资料?
  • 华为OD机试真题Java实现【比赛评分】真题+解题思路+代码(20222023)
  • 【linux】——gcc/g++,make/makefile的简单使用
  • 追梦之旅【数据结构篇】——详解C语言动态实现带头结点的双向循环链表结构
  • 华为OD机试真题Python实现【水仙花数 2】真题+解题思路+代码(20222023)
  • 【原创】java+swing+txt学生学籍管理系统设计与实现
  • GCN项目实战1-SimGNN
  • 经过深思熟虑后的接口测试自动化的总结与思考
  • 电脑自带的录屏放在哪里了?轻松弄懂,看这篇文章就明白了
  • 华为OD机试真题Java实现【字符串分割】真题+解题思路+代码(20222023)
  • 【数据库】Apache Doris : 一个开源 MPP 数据库的架构与实践