常见正则验证

reg.js

// 只需要将这些代码放到公共js文件然后在main.js页面全局注册就行了,真的是很耐斯的哈!
// (有些校验我也看不懂,但是不耽搁我们自己配置)
const numberReg = /^-?[1-9][0-9]?.?[0-9]*$/
const intReg = /^-?[1-9][0-9]*$/
const phoneReg = /^1[0-9]{10,10}$/
const emailReg = /^\w+([-+.']\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$/
const pwdReg = /^.{6,16}$/
const inviteCodeReg = /^[a-zA-Z0-9]{6,16}$/
const UnifiedCodeReg = /^([0-9A-HJ-NPQRTUWXY]{2}\d{6}[0-9A-HJ-NPQRTUWXY]{10}|[1-9]\d{14})$/
const websiteReg = /^((https|http|ftp|rtsp|mms){0,1}(:\/\/){0,1})www\.(([A-Za-z0-9-~]+)\.)+([A-Za-z0-9-~\/])+$/
const cardId = /^[1-9]\d{5}(18|19|([23]\d))\d{2}((0[1-9])|(10|11|12))(([0-2][1-9])|10|20|30|31)\d{3}[0-9Xx]$/
export default {
	isNumber: function(val) {
		return numberReg.test(val)
	},
	isInt: function(val) {
		return intReg.test(val)
	},
	// 验证手机号
	isPhone: function(val) {
		return phoneReg.test(val)
	},
	// 验证邮箱
	isEmail: function(val) {
		return emailReg.test(val)
	},
	isPwd: function(val) {
		return pwdReg.test(val)
	},
	isInviteCode: function(val) {
		return inviteCodeReg.test(val)
	},
	// 验证统一社会信用代码
	isUnifiedCode: function(val) {
		return UnifiedCodeReg.test(val)
	},
	// 网址校验
	iswebsite: function(val) {
		return websiteReg.test(val)
	},
	//身份证验证
	iscardId: function(val) {
		return cardId.test(val)
	},

	validate: function(data, rules) {
		let res = {
			isOk: true,
			errmsg: ''
		}
		if (!rules || !rules.length) {
			return res
		}
		for (let rule of rules) {
			// rule: {name:'', type:'', errmsg:'', min:1, max:2, eq:'', required:Boolean, regex:''}
			if (!rule || !rule.name || !rule.type) {
				continue
			}

			// 如果值不存在
			if (!data[rule.name]) {
				// 如果是必填项就返回错误提示,required可以作为type是为了不同的type能给用户不同的提示
				if (rule.type === 'required' || rule.required) {
					res = {
						isOk: false,
						errmsg: rule.errmsg
					}
					if (!res.errmsg) {
						res.errmsg = '请正确输入所有数据' //默认提示
					}
					return res
				}
				// 如果不是必填项就跳过
				continue
			}
			switch (rule.type) {
				// required 上面已经判断过了
				case 'equals':
				case 'eq':
					if (data[rule.name] !== data[rule.eqName]) {
						res = {
							isOk: false,
							errmsg: rule.errmsg
						}
					}
					break
				case 'number':
					if (!numberReg.test(data[rule.name])) {
						res = {
							isOk: false,
							errmsg: rule.errmsg
						}
					}
					break
				case 'int':
					if (!intReg.test(data[rule.name])) {
						res = {
							isOk: false,
							errmsg: rule.errmsg
						}
					}
					break
				case 'phone':
					if (!phoneReg.test(data[rule.name])) {
						res = {
							isOk: false,
							errmsg: rule.errmsg
						}
					}
					break
				case 'email':
					if (!emailReg.test(data[rule.name])) {
						res = {
							isOk: false,
							errmsg: rule.errmsg
						}
					}
					break
				case 'pwd':
					if (!pwdReg.test(data[rule.name])) {
						res = {
							isOk: false,
							errmsg: rule.errmsg
						}
					}
					break
				case 'inviteCode':
					if (!inviteCodeReg.test(data[rule.name])) {
						res = {
							isOk: false,
							errmsg: rule.errmsg
						}
					}
					break
				case 'range': // 数字类型的值取值范围
					// {name: 'xxx', type: 'range', min: 6, max: 6, required: true, errmsg: 'xxx'}
					let val = data[rule.name]
					if (val) {
						if (numberReg.test(val)) {
							if (rule.min && val < rule.min) {
								res = {
									isOk: false,
									errmsg: rule.errmsg
								}
							} else if (rule.max && val > rule.max) {
								res = {
									isOk: false,
									errmsg: rule.errmsg
								}
							}
						} else {
							res = {
								isOk: false,
								errmsg: rule.errmsg
							}
						}
					}
					break
				case 'lengthRange': // 字符串长度取值范围
					// {name: 'xxx', type: 'lengthRange', min: 6, max: 6, errmsg: 'xxx'}
					let le = data[rule.name] ? data[rule.name].length : 0
					if (rule.min && le < rule.min) {
						res = {
							isOk: false,
							errmsg: rule.errmsg
						}
					} else if (rule.max && le > rule.max) {
						res = {
							isOk: false,
							errmsg: rule.errmsg
						}
					}
					break
				case 'regex': // 自定义正则表达式
					// {name: 'xxx', type: 'regex', regex: /^1[0-9]{10,10}$/, errmsg: 'xxx'}
					if (rule.regex && !rule.regex.test(data[rule.name])) {
						res = {
							isOk: false,
							errmsg: rule.errmsg
						}
					}
					break
			}
			// 发现任何一个错误就立即返回,后面的不再判断
			if (!res.isOk) {
				if (!res.errmsg) {
					res.errmsg = '请正确输入所有数据' //默认提示
				}
				return res
			}
		}
		return res
	}
}


// 使用方法
// 1.单独使用
// if (!this.$validate.isPhone(要验证的手机号)) {
//   uni.showToast({
//     icon: 'none',
//     title: '请输入正确的手机号'
//   })
// }

// 2.验证整个表单
// let loginRules = [
//   {name: 'tel', required: true, type: 'phone', errmsg: '请输入正确的手机号'},
//   {name: 'pwd', type: 'required', errmsg: '请输入密码'},
//   {name: 'pwd', type: 'pwd', errmsg: '密码须是6~16位字符'},
//   {name: 'pwd2', type: 'eq', eqName: 'pwd', required: true, errmsg: '两次输入密码不一致'},
//   {name: 'telCode', type: 'required', errmsg: '请输入验证码'},
//   {name: 'telCode', type: 'lengthRange', min: 6, max: 6, errmsg: '请正确输入验证码'}
// ]
// let valLoginRes = this.$validate.validate(this.userInfo, loginRules)
// if (!valLoginRes.isOk) {
//   uni.showToast({
//     icon: 'none',
//     title: valLoginRes.errmsg
//   })
//   return false
// }

全局注册

import validate from './api/reg.js'
Vue.prototype.$validate = validate
const app = new Vue({
   validate
})

页面调用

调用
if (!this.$validate.isPhone(this.$store.state.mobile)) {//this.$store.state.mobile是输入框内容
				uni.showToast({
					icon: 'none',
					title: '请输入正确的手机号'
				});
    }else{
        //下一步操作    
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
在使用JavaScript正则表达式验证英文名时,我们可以根据一些常见的规则来编写正则表达式。 首先,英文名通常由一个或多个英文字母组成,因此我们可以使用[a-zA-Z]来表示英文字母。接下来,我们需要考虑英文名中可以包含的一些特殊字符,例如空格和连字符。空格可以使用\s来表示,连字符可以直接使用-表示。 然后,我们需要考虑英文名的长度。根据实际需求,可以使用{min, max}来表示英文名的最小和最大长度。例如,{2, 10}表示英文名的长度应在2到10个字符之间。 最后,我们需要考虑英文名中是否可以包含其他字符,例如数字和标点符号。根据实际需求,可以使用[^]来表示英文名中不应包含的字符。例如,[^0-9]表示英文名中不应包含数字。 综上所述,我们可以使用以下正则表达式来验证英文名: ^[a-zA-Z\s-]{2,10}$ 它表示英文名由2到10个英文字母、空格和连字符组成。 以下是一个示例,演示如何使用这个正则表达式来验证英文名: ``` const nameRegex = /^[a-zA-Z\s-]{2,10}$/; const name = "John Doe"; if (nameRegex.test(name)) { console.log("英文名合法"); } else { console.log("英文名不合法"); } ``` 注意,此处只是简单的示例,实际情况下可能需要根据具体需求进行调整和扩展。同时,对于不同的语言和文化背景,英文名的规则可能会有所不同,需要根据实际情况来确定符合要求的正则表达式。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

PINK_CODE

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值