reg.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) {
if (!rule || !rule.name || !rule.type) {
continue
}
if (!data[rule.name]) {
if (rule.type === 'required' || rule.required) {
res = {
isOk: false,
errmsg: rule.errmsg
}
if (!res.errmsg) {
res.errmsg = '请正确输入所有数据'
}
return res
}
continue
}
switch (rule.type) {
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':
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':
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':
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
}
}
全局注册
import validate from './api/reg.js'
Vue.prototype.$validate = validate
const app = new Vue({
validate
})
页面调用
调用
if (!this.$validate.isPhone(this.$store.state.mobile)) {
uni.showToast({
icon: 'none',
title: '请输入正确的手机号'
});
}else{
}