vue 身份证校验、识别性别/生日/年龄

vue 身份证格式校验_chen_ai_tao的博客-CSDN博客_vue 身份证校验

Vue中根据输入的身份证号识别年龄、性别_cx&lavender的博客-CSDN博客_vue中根据省份证获取年龄和性别

表单项绑定@input 事件

 <el-form ref="personForm" :rules="personRules" :model="person" label-width="1.25rem">
    <el-form-item label="身份证号" prop="cardNo">
        <el-input v-model="person.cardNo" @input="inputChange"></el-input>
    </el-form-item>
    <el-form-item label="性别" prop="gender">
         <el-select disabled v-model="person.gender" placeholder="请选择性别">
              <el-option v-for="(item, index) in genderList" :key="index"         
                         :label="item.label" :value="item.value"></el-option>
         </el-select>
    </el-form-item>
    <el-form-item label="出生日期" prop="birthday">
          <el-date-picker disabled type="date" placeholder="请选择出生日期" v- 
                          model="person.birthday" value-format="yyyy-MM-dd" style="width: 
                          100%;">
          </el-date-picker>
    </el-form-item>
</el-form>

 定义身份证校验规则

 data() {
    const isCnNewID = (rule, value, callback) => {
      var arrExp = [7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2];//加权因子
      var arrValid = [1, 0, "X", 9, 8, 7, 6, 5, 4, 3, 2];//校验码
      if (/^\d{17}\d|x$/i.test(value)) {
        var sum = 0, idx;
        for (var i = 0; i < value.length - 1; i++) {
          // 对前17位数字与权值乘积求和
          sum += parseInt(value.substr(i, 1), 10) * arrExp[i];
        }
        // 计算模(固定算法)
        idx = sum % 11;
        // 检验第18为是否与校验码相等
        if (arrValid[idx] == value.substr(17, 1).toUpperCase()) {
          callback()
        } else {
          this.person.gender = ''
          this.person.birthday = ''
          callback("身份证格式有误")
        }
      } else {
        this.person.gender = ''
        this.person.birthday = ''
        callback("身份证格式有误")
      }
    }
    return {
        personRules: {
        //身份证校验规则
        cardNo: [
          { required: true, message: "请输入身份证号", trigger: "blur" },
          {	//调用定义的方法校验格式是否正确
            validator: isCnNewID, trigger: "blur"
          }
        ],
}
    }
}

识别性别、出生日期

methods: {
    // 身份证识别性别出生日期
    inputChange() {
      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]$/;
      if (reg.test(this.person.cardNo)) {
        var org_birthday = this.person.cardNo.substring(6, 14);
        var org_gender = this.person.cardNo.substring(16, 17);
        var sex = org_gender % 2 == 1 ? "男" : "女";
        var birthday =
          org_birthday.substring(0, 4) +
          "-" +
          org_birthday.substring(4, 6) +
          "-" +
          org_birthday.substring(6, 8);
        var birthdays = new Date(birthday.replace(/-/g, "-"));
        this.person.gender = sex;
        this.person.birthday = birthdays;
      } else {
        return false;
      }
    },
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值