Vue常用表单校验

加权身份证号码校验

const reg = /(^[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]$)|(^[1-9]\d{7}((0[1-9])|(10|11|12))(([0-2][1-9])|10|20|30|31)\d{3}$)/;
    if (reg.test(value)) {

      //18位身份证需要验证最后一位校验位
      if(value.length == 18){
        let valueList = value.split('');
        //∑(ai×Wi)(mod 11)
        //加权因子
        let factor = [ 7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2 ];
        //校验位
        let parity = [ 1, 0, 'X', 9, 8, 7, 6, 5, 4, 3, 2 ];
        let sum = 0;
        let ai = 0;
        let wi = 0;
        for (let i = 0; i < 17; i++)
        {
          ai = value[i];
          wi = factor[i];
          sum += ai * wi;
        }
        if(parity[sum % 11] != valueList[17].toUpperCase()){
          return callback(new Error('该身份证号校验未通过'));
        }}
       callback()
    } else {
      return callback(new Error('请输入正确的身份证号'));
    }

手机号与座机号校验

 const reg = /^1[3|4|5|7|8][0-9]\d{8}$/
    const reg2 = /^\d{3}-\d{7,8}|\d{4}-\d{7,8}$/
    if (reg.test(value) || reg2.test(value)) {
      callback();
    } else {
     return ElMessage.error("请输入正确格式");
    }
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值