element 表单验证

2024-09-05 10:58
文章标签 表单 验证 element

本文主要是介绍element 表单验证,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

集合了常用的一些验证
在这里插入图片描述
组件:
在这里插入图片描述

export {validatePassword, // 密码验证validateLongitude, // 经度验证validateLatitude, // 纬度验证validatePhone, // 手机号验证validateBankNum, // 银行账户验证validateStablePhone, // 座机号验证validateIdCard, // 身份证验证validateEmail, // 邮箱格式验证validateNum, // 只能为数字validateSort, // 排序值验证validateCarCard, // 车牌号验证(兼容新能源)validateUsername, // 用户名验证 4到16位(字母,数字,下划线,减号)validateUserCode, // 统一社会信用代码验证validateChina, // 中文/汉字验证validateEnglish, // 英文验证validatePostal, // 中国邮政编码验证validatePrice // 价格验证(保留两位小数)
}
//  validatePassword 密码验证;
const validatePassword = (rule, value, callback) => {const regPassword = /^(?=.*[A-Za-z])(?=.*\d)(?=.*[#$%&_=])[A-Za-z\d#$%&_=]{8,18}$/if (value !== '') {if (value.length < 8) {callback(new Error('请输入至少8位的密码'))return false} else if (value.length > 18) {callback(new Error('密码长度不能超过18位'))return false} else if (!regPassword.test(value)) {callback(new Error('密码必须包含字母、数字和特殊字符(#$%&_=)'))return false} else {callback()}} else {return callback(new Error('密码不能为空'))}
}// validateLongitude 经度验证;
const validateLongitude = (rule, value, callback) => {var reg = /^\d+\.?\d{0,6}$/if (value === '') {return callback(new Error('经度值不能为空'))} else if (value < -180 || value > 180 || isNaN(value)) {callback(new Error('请输入-180到180之间的经度值'))} else if (!reg.test(value)) {callback(new Error('最多允许6位小数'))} else {callback()}
}// validateLatitude 纬度验证;
const validateLatitude = (rule, value, callback) => {var reg = /^\d+\.?\d{0,6}$/if (value === '') {return callback(new Error('纬度值不能为空'))} else if (value < -90 || value > 90 || isNaN(value)) {callback(new Error('请输入-90到90之间的纬度值'))} else if (!reg.test(value)) {callback(new Error('最多允许6位小数'))} else {callback()}
}// validatePhone 手机号验证;
const validatePhone = (rule, value, callback) => {if (!value) {return callback(new Error('手机号不能为空'))} else {const reg = /^(?:(?:\+|00)86)?1(?:(?:3[\d])|(?:4[5-7|9])|(?:5[0-3|5-9])|(?:6[5-7])|(?:7[0-8])|(?:8[\d])|(?:9[1|8|9]))\d{8}$/if (reg.test(value)) {callback()} else {return callback(new Error('请输入正确的手机号'))}}
}// validateBankNum 银行账户验证;
const validateBankNum = (rule, value, callback) => {if (value) {if (!/^([1-9]{1})(\d{15}|\d{18})$/.test(value)) {callback(new Error('银行账户有误,请重填'))return false} else {callback()}} else {return callback(new Error('银行账户不能为空'))}
}// validateStablePhone 座机号验证
const validateStablePhone = (rule, value, callback) => {if (value) {const phoneNum = /^((0\d{2,3})-)(\d{7,8})(-(\d{3,}))?$/if (!phoneNum.test(value)) {callback(new Error('座机号码有误,请重填'))return false} else {callback()}} else {callback()}
}// validateIdCard 身份证验证(兼容18/15位);
const validateIdCard = (rule, value, callback) => {if (value) {const regIdCard = /(^\d{8}(0\d|10|11|12)([0-2]\d|30|31)\d{3}$)|(^\d{6}(18|19|20)\d{2}(0\d|10|11|12)([0-2]\d|30|31)\d{3}(\d|X|x)$)/if (!regIdCard.test(value)) {callback(new Error('身份证号填写有误'))return false} else {callback()}} else {return callback(new Error('身份证号不能为空'))}
}// validateEmail 邮箱格式验证;
const validateEmail = (rule, value, callback) => {const mailReg = /^([a-zA-Z0-9_-])+@([a-zA-Z0-9_-])+(.[a-zA-Z0-9_-])+/if (!value) {return callback(new Error('邮箱不能为空'))}setTimeout(() => {if (mailReg.test(value)) {callback()} else {callback(new Error('请输入正确的邮箱格式'))}}, 100)
}//  validateNum 只能为数字
const validateNum = (rule, value, callback) => {const age = /^[0-9]*$/if (!age.test(value)) {callback(new Error('只能为数字'))} else {callback()}
}// validateSort 排序值验证;
const validateSort = (rule, value, callback) => {if (value !== '') {if (value <= 0) {callback(new Error('排序值填写错误,请重填正整数'))return false} else {callback()}} else {callback()}
}// validateCarCard 车牌号验证;(兼容新能源车牌)
const validateCarCard = (rule, value, callback) => {if (value) {const CarCard = /^(?:[京津沪渝冀豫云辽黑湘皖鲁新苏浙赣鄂桂甘晋蒙陕吉闽贵粤青藏川宁琼使领 A-Z]{1}[A-HJ-NP-Z]{1}(?:(?:[0-9]{5}[DF])|(?:[DF](?:[A-HJ-NP-Z0-9])[0-9]{4})))|(?:[京津沪渝冀豫云辽黑湘皖鲁新苏浙赣鄂桂甘晋蒙陕吉闽贵粤青藏川宁琼使领 A-Z]{1}[A-Z]{1}[A-HJ-NP-Z0-9]{4}[A-HJ-NP-Z0-9 挂学警港澳]{1})$/if (!CarCard.test(value)) {callback(new Error('车牌号有误,请重填'))return false} else {callback()}} else {callback()}
}// validatePostal 中国邮编验证
const validatePostal = (rule, value, callback) => {if (value) {const Postal = /^(0[1-7]|1[0-356]|2[0-7]|3[0-6]|4[0-7]|5[1-7]|6[1-7]|7[0-5]|8[013-6])\d{4}$/if (!Postal.test(value)) {callback(new Error('邮政编码有误,请重填'))return false} else {callback()}} else {callback()}
}// validateUsername 用户名验证,4到16位(字母,数字,下划线,减号)
const validateUsername = (rule, value, callback) => {const name = /^[a-zA-Z0-9_-]{4,16}$/.test(value)if (!name) {callback(new Error('用户名有误,请输入4到16位(字母,数字,下划线,减号)'))} else {callback()}
}// validateUserCode 统一社会信用代码验证;
const validateUserCode = (rule, value, callback) => {if (value) {const Code = /^(([0-9A-Za-z]{15})|([0-9A-Za-z]{18})|([0-9A-Za-z]{20}))$/if (!Code.test(value)) {callback(new Error('统一社会信用代码输入有误'))return false} else {callback()}} else {callback()}
}// validateChina 中文/汉字验证
const validateChina = (rule, value, callback) => {if (value) {const Code = /^(?:[\u3400-\u4DB5\u4E00-\u9FEA\uFA0E\uFA0F\uFA11\uFA13\uFA14\uFA1F\uFA21\uFA23\uFA24\uFA27-\uFA29]|[\uD840-\uD868\uD86A-\uD86C\uD86F-\uD872\uD874-\uD879][\uDC00-\uDFFF]|\uD869[\uDC00-\uDED6\uDF00-\uDFFF]|\uD86D[\uDC00-\uDF34\uDF40-\uDFFF]|\uD86E[\uDC00-\uDC1D\uDC20-\uDFFF]|\uD873[\uDC00-\uDEA1\uDEB0-\uDFFF]|\uD87A[\uDC00-\uDFE0])+$/if (!Code.test(value)) {callback(new Error('只能输入中文/汉字'))return false} else {callback()}} else {callback()}
}// validateEnglish 英文验证
const validateEnglish = (rule, value, callback) => {if (value) {const Code = /^[a-zA-Z]+$/if (!Code.test(value)) {callback(new Error('只能输入英文'))return false} else {callback()}} else {callback()}
}//  validatePrice 价格验证,保留两位小数
const validatePrice = (rule, value, callback) => {const reg = /^\d+.?\d{0,2}$/if (!value) {callback(new Error('请输入价格'))} else if (!Number(value)) {callback(new Error('请输入数字值'))} else {if (reg.test(value)) {callback()} else {callback(new Error('小数点后最多只能输入两位'))}}
}
/* eslint-disable no-new */

页面引入:

import { validatePhone, validateEmail } from '@/utils/validator.js'
phone: [{ required: true, validator: validatePhone, trigger: 'blur' }],
email: [{ required: true, validator: validateEmail, trigger: 'blur' }]

这篇关于element 表单验证的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Linux内核参数配置与验证详细指南

《Linux内核参数配置与验证详细指南》在Linux系统运维和性能优化中,内核参数(sysctl)的配置至关重要,本文主要来聊聊如何配置与验证这些Linux内核参数,希望对大家有一定的帮助... 目录1. 引言2. 内核参数的作用3. 如何设置内核参数3.1 临时设置(重启失效)3.2 永久设置(重启仍生效

opencv图像处理之指纹验证的实现

《opencv图像处理之指纹验证的实现》本文主要介绍了opencv图像处理之指纹验证的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录一、简介二、具体案例实现1. 图像显示函数2. 指纹验证函数3. 主函数4、运行结果三、总结一、

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

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

最新Spring Security实战教程之表单登录定制到处理逻辑的深度改造(最新推荐)

《最新SpringSecurity实战教程之表单登录定制到处理逻辑的深度改造(最新推荐)》本章节介绍了如何通过SpringSecurity实现从配置自定义登录页面、表单登录处理逻辑的配置,并简单模拟... 目录前言改造准备开始登录页改造自定义用户名密码登陆成功失败跳转问题自定义登出前后端分离适配方案结语前言

Gin框架中的GET和POST表单处理的实现

《Gin框架中的GET和POST表单处理的实现》Gin框架提供了简单而强大的机制来处理GET和POST表单提交的数据,通过c.Query、c.PostForm、c.Bind和c.Request.For... 目录一、GET表单处理二、POST表单处理1. 使用c.PostForm获取表单字段:2. 绑定到结

javaScript在表单提交时获取表单数据的示例代码

《javaScript在表单提交时获取表单数据的示例代码》本文介绍了五种在JavaScript中获取表单数据的方法:使用FormData对象、手动提取表单数据、使用querySelector获取单个字... 方法 1:使用 FormData 对象FormData 是一个方便的内置对象,用于获取表单中的键值

Python爬虫selenium验证之中文识别点选+图片验证码案例(最新推荐)

《Python爬虫selenium验证之中文识别点选+图片验证码案例(最新推荐)》本文介绍了如何使用Python和Selenium结合ddddocr库实现图片验证码的识别和点击功能,感兴趣的朋友一起看... 目录1.获取图片2.目标识别3.背景坐标识别3.1 ddddocr3.2 打码平台4.坐标点击5.图

C#提取PDF表单数据的实现流程

《C#提取PDF表单数据的实现流程》PDF表单是一种常见的数据收集工具,广泛应用于调查问卷、业务合同等场景,凭借出色的跨平台兼容性和标准化特点,PDF表单在各行各业中得到了广泛应用,本文将探讨如何使用... 目录引言使用工具C# 提取多个PDF表单域的数据C# 提取特定PDF表单域的数据引言PDF表单是一

Vue项目中Element UI组件未注册的问题原因及解决方法

《Vue项目中ElementUI组件未注册的问题原因及解决方法》在Vue项目中使用ElementUI组件库时,开发者可能会遇到一些常见问题,例如组件未正确注册导致的警告或错误,本文将详细探讨这些问题... 目录引言一、问题背景1.1 错误信息分析1.2 问题原因二、解决方法2.1 全局引入 Element

element-ui下拉输入框+resetFields无法回显的问题解决

《element-ui下拉输入框+resetFields无法回显的问题解决》本文主要介绍了在使用ElementUI的下拉输入框时,点击重置按钮后输入框无法回显数据的问题,具有一定的参考价值,感兴趣的... 目录描述原因问题重现解决方案方法一方法二总结描述第一次进入页面,不做任何操作,点击重置按钮,再进行下