亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

vue之郵箱、密碼、手機(jī)號(hào)碼等輸入驗(yàn)證規(guī)則說(shuō)明

 更新時(shí)間:2023年10月18日 09:01:53   作者:Pisces_224  
這篇文章主要介紹了vue之郵箱、密碼、手機(jī)號(hào)碼等輸入驗(yàn)證規(guī)則說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

vue郵箱、密碼、手機(jī)號(hào)碼等輸入驗(yàn)證規(guī)則

手機(jī)號(hào)

const checkPhone = (rule, value, callback) => {
  const phoneReg = /^1[34578]\d{9}$$/;
  if (!value) {
    return callback(new Error("電話號(hào)碼不能為空"));
  }
  setTimeout(() => {
    if (!Number.isInteger(+value)) {
      callback(new Error("請(qǐng)輸入數(shù)字值"));
    } else {
      if (phoneReg.test(value)) {
        callback();
      } else {
        callback(new Error("電話號(hào)碼格式不正確"));
      }
    }
  }, 100);
};

郵箱

const checkEmail = (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("請(qǐng)輸入正確的郵箱格式"));
    }
  }, 100);
};

密碼

var validatePass = (rule, value, callback) => {
        if (value === '') {
          callback(new Error('請(qǐng)?jiān)O(shè)置正確格式的密碼'));
        } else if(value.length < 6){
          callback(new Error('密碼長(zhǎng)度最小6位'));
        }else{
          callback();
        }
      };

調(diào)用:

<el-form
       :model="addForm"
       :label-position="labelPosition"
       :rules="addFormRules"
       ref="addFormRef"
       label-width="80px"
   >
<el-form-item label="郵箱" prop="email">
  <el-input v-model="addForm.email"></el-input>
</el-form-item>
<el-form-item label="手機(jī)" prop="phoneNumber">
  <el-input v-model="addForm.phoneNumber"></el-input>
</el-form-item>

data() {
	return {
	
		addForm: {},
		addFormRules: {
			email: [{ required: true, validator: checkEmail, trigger: "blur" }],
			phoneNumber: [{ required: false, message: "請(qǐng)輸入聯(lián)系方式", validator: checkPhone, trigger: "blur"}],
		}
	}
}

全局驗(yàn)證規(guī)則腳本,需要的地方引入即可:

1.給頁(yè)面表單對(duì)象添加驗(yàn)證屬性

:rules=“registerRules” ref=“registerForm”

為el-form-item每個(gè)表單子項(xiàng)添加 prop 屬性, 例如

<el-form-item prop="username">
  <el-input name="username" type="text" v-model="registerForm.username" placeholder="請(qǐng)?jiān)O(shè)置登錄用戶(hù)名"></el-input>
</el-form-item>

rules是一個(gè)驗(yàn)證規(guī)則對(duì)象,因此需要在data()頁(yè)面數(shù)據(jù)里添加registerRules對(duì)象:

      registerRules: {
        username: [{ required: true, trigger: 'blur', validator: validateUsername }],
        password: [{ required: true, trigger: 'blur', validator: validatePassword }],
        password_repeat: [{ required: true, trigger: 'blur', validator: this.validatePassRepeat }],
        bind_phone: [{ required: true, trigger: 'blur', validator: validatePhone }],
        realname: [{ required: true, trigger: 'blur', validator: validateRealName }],
        id_number: [{ required: true, trigger: 'blur', validator: validateIdNumber }]
      },

3.創(chuàng)建validate.js全局驗(yàn)證規(guī)則腳本,供頁(yè)面靈活引入

/* 驗(yàn)證賬號(hào) */
export function validateUsername(rule, value, callback) {
  if (value.length < 6 || value.length > 20) {
    return callback(new Error('用戶(hù)名不得小于6個(gè)或大于20個(gè)字符!'))
  } else {
    callback()
  }
}
 
/* 驗(yàn)證密碼 */
export function validatePassword(rule, value, callback) {
  if (value.length < 6) {
    return callback(new Error('密碼不能小于6位'))
  } else {
    callback()
  }
}
 
/* 合法郵箱 */
export function validateEmail(rule, value, callback) {
  const emailReg = /^(([a-zA-Z0-9_\-\.]+)@([a-zA-Z0-9_\-\.]+)\.([a-zA-Z]{2,5}){1,25})$/
  if (!value) {
    return callback(new Error('郵箱不能為空!!'))
  }
  setTimeout(() => {
    if (!emailReg.test(value)) {
      return callback(new Error('郵箱格式錯(cuò)誤'))
    } else {
      callback()
    }
  }, 100)
}
 
/* 合法手機(jī)號(hào) */
export function validatePhone(rule, value, callback) {
  const phoneReg = /^[1][3,4,5,7,8][0-9]{9}$/
  if (!value) {
    return callback(new Error('手機(jī)號(hào)碼不能為空!!'))
  }
  setTimeout(() => {
    if (!phoneReg.test(value)) {
      return callback(new Error('手機(jī)號(hào)碼格式錯(cuò)誤'))
    } else {
      callback()
    }
  }, 100)
}
 
/* 合法真實(shí)姓名 */
export function validateRealName(rule, value, callback) {
  const realnameReg = /^([a-zA-Z0-9\u4e00-\u9fa5\·]{1,10})$/
  if (!value) {
    return callback(new Error('真實(shí)姓名不能為空!!'))
  }
  setTimeout(() => {
    if (!realnameReg.test(value)) {
      return callback(new Error('您的真實(shí)姓名格式錯(cuò)誤,請(qǐng)輸入英文或漢字!'))
    } else {
      callback()
    }
  }, 100)
}
 
/* 合法身份證 */
export function validateIdNumber(rule, value, callback) {
  const idNumberReg = /^[1-9]\d{7}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{3}$|^[1-9]\d{5}[1-9]\d{3}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{3}([0-9]|X)$/
  if (!value) {
    return callback(new Error('身份證號(hào)碼不能為空!!'))
  }
  setTimeout(() => {
    if (!idNumberReg.test(value)) {
      return callback(new Error('您的身份證號(hào)碼格式錯(cuò)誤!'))
    } else {
      callback()
    }
  }, 100)
}
 
 

4.引入全局驗(yàn)證規(guī)則即可

import { validateUsername, validatePassword, validatePhone, validateRealName, validateIdNumber } from '../../utils/validate'

另外,大部分驗(yàn)證函數(shù)都是通過(guò)正則表達(dá)式來(lái)驗(yàn)證的,以下還有很多常見(jiàn)的正則式:

/* 合法的https或ftp地址 */
const urlregex = /^(https?|ftp):\/\/([a-zA-Z0-9.-]+(:[a-zA-Z0-9.&%$-]+)*@)*((25[0-5]|2[0-4][0-9]|1[0-9]{2}|[1-9][0-9]?)(\.(25[0-5]|2[0-4][0-9]|1[0-9]{2}|[1-9]?[0-9])){3}|([a-zA-Z0-9-]+\.)*[a-zA-Z0-9-]+\.(com|edu|gov|int|mil|net|org|biz|arpa|info|name|pro|aero|coop|museum|[a-zA-Z]{2}))(:[0-9]+)*(\/($|[a-zA-Z0-9.,?'\\+&%$#=~_-]+))*$/
  
/* 小寫(xiě)字母 */
const reg = /^[a-z]+$/
 
/* 大寫(xiě)字母 *
const reg = /^[A-Z]+$/
/* 大小寫(xiě)字母*/
const reg = /^[A-Za-z]+$/

通過(guò)reg.test()函數(shù)判斷是否符合正則式:

/* 判斷str是否符合reg正則式,返回真或者假 */
reg.test(str)
 

總結(jié)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

最新評(píng)論