后台-表单验证-cv

文章介绍了如何在前端实现通用的表单验证方法,包括正整数、数字范围、邮箱和电话号码的验证。同时,通过柯里化技术创建了一个自定义验证函数`formValidate`,该函数可以根据输入的验证规则和错误信息生成具体的验证方法,简化了表单验证的代码编写。示例展示了在页面中如何使用这些验证规则。
摘要由CSDN通过智能技术生成

实现通用的表单验证方法:

utils/validateItem.ts

// 应为正整数,且范围为1 ~ 99999
export function oneTo99999TestFlag(str) {
	const reg = /^([1-9]{1}[0-9]{0,4})$/
	return reg.test(str)
}

// 应为数字,且范围为1 ~ 99999(可小数)
export function oneTo99999DecimalTestFlag(str) {
	const reg = /99999|(^[1-9]{1}[0-9]{0,3}[0-8]{0,1}(\.\d{1,2})?$)/
	return reg.test(str)
}

// 应为数字,且范围为0 ~ 99999999.99且大于0
export function zeroTo99999999DecimalTestFlag(str) {
	const reg = /(^[1-9](\d{0,7})(\.\d{1,2})?$)|(^0(\.\d{1,2})$)/
	return reg.test(str)
}

// 请输入正确的联系邮箱
export function emailTestFlag(str) {
	const reg = /^([a-zA-Z0-9_-])+@([a-zA-Z0-9_-])+(.[a-zA-Z0-9_-])+/
	return reg.test(str)
}

// 请输入正确的11位数联系电话
export function phoneTestFlag(str) {
	const reg = /^(?:(?:\+|00)86)?1(?:(?:3[\d])|(?:4[5-79])|(?:5[0-35-9])|(?:6[5-7])|(?:7[0-8])|(?:8[\d])|(?:9[\d]))\d{8}$/
	return reg.test(str)
}

增加一个柯里化方法,用来生成表单验证函数:

utils/validate.ts

import * as Validates from './validateItem'
// 生成自定义校验函数
export const formValidate = (key, msg, isRequired?) => (rule, value, cb) => {
	if (Validates[key](value)) {
		cb()
	} else {
		if (isRequired == false && !value) {
			cb()
		} else {
			cb(new Error(msg))
		}
	}
}

页面使用

非必填 传false

	import { formValidate } from '@/utils/validate'


const abilityRules = ref<FormRules>({
		phoneNumber: [
			{
				required: true,
				message: '请输入联系电话',
				trigger: 'blur',
			},
			{
				validator: formValidate('phoneTestFlag', '请输入正确的11位数联系电话'),
				trigger: ['blur', 'change'],
			},
		],
		email: [
			{
				required: true,
				message: '请输入联系邮箱',
				trigger: 'blur',
			},
			{
				validator: formValidate('emailTestFlag', '请输入正确的联系邮箱'),
				trigger: ['blur', 'change'],
			},
		],

		fixedAssets: [
			{
				validator: formValidate('oneTo99999DecimalTestFlag', '应为数值,且范围为1 ~ 99999', false),
				trigger: ['blur', 'change'],
			},
		],
		lastYearTotalSales: [
			{
				validator: formValidate('oneTo99999DecimalTestFlag', '应为数值,且范围为1 ~ 99999', false),
				trigger: ['blur', 'change'],
			},
		],
		employeeCount: [
			{
				validator: formValidate('oneTo99999TestFlag', '应为正整数,且范围为1 ~ 99999', false),
				trigger: ['blur', 'change'],
			},
		],
	})

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值