vue中如何进行身份证合法性校验(身份证18位,包含最后一位数字/字母)

本文介绍了在Vue项目中,结合Element UI组件库,如何实现身份证18位合法性的校验,包括输入限制和自定义校验规则。通过封装校验规则,优化代码结构,降低组件代码复杂性。
摘要由CSDN通过智能技术生成

前言

最近在做项目过程中,测试组人员对添加表单中的身份信息提出了需求,在填写身份证信息时,希望能对所填信息进行合法性校验。比如身份证的位数(目前二代身份证都是18位)、地区编号(所在省(市,旗,区)的行政区代码)、出生年月日(月份所对应的28天/29天/30天/31天)、顺序码(第十五到十七位,第十七位奇数是男性,偶数是女性),校验码(第十八位,如果尾号是10就用X代替了)。

正文

有了新需求,就要满足用户的要求。接下来将介绍我是如何实现身份校验的。项目中使用的前端框架位vue,组件库为Element ui。

1、 首先,根据实际情况,目前我们使用的身份证由18位构成,包括数字和字母X。那么,在input输入框中就需要限制用户输入的数据类型。

        <el-input
              v-model="addStudentList.identitytionId"
              // 使用正则表达式,只能输入阿拉伯数字0-9,和字母X(大写)
             onkeyup="this.value=this.value.replace(/[^\X0-9]/g, '')">
            
         </el-input>
            

2、其次,查看Element ui 组件库官网可知,我们可以自定义表单的校验规则。官网中给出的实例为:

在这里插入图片描述

  export default {
   
    data() {
   
      var checkAge = (rule, value, callback) => {
   
        if (!value) {
   
          return callback(new Error('年龄不能为空'));
        }
        setTimeout(() => {
   
          if (!Number.isInteger(value)) {
   
            callback(new Error('请输入数字值'));
          } else {
   
            if (value < 18) {
   
              callback(new Error('必须年满18岁'));
            } else {
   
              callback();
            }
          }
        }, 1000);
      };
      var validatePass = (rule, value, callback) => {
   
        if (value === '') {
   
          callback(new Error('请输入密码'));
        } else {
   
          if (this.ruleForm.checkPass !== '') {
   
            this.$refs.ruleForm.validateField('checkPass');
          }
          callback();
        }
      };
      var validatePass2 = (rule, value, callback) => {
   
        if (value === '') {
   
          callback(new Error('请再次输入密码'));
        } else if (value !== this.ruleForm.pass) {
   
          callback(new Error('两次输入密码不一致!'));
        } else {
   
          callback();
        }
      };
      return {
   
        ruleForm: {
   
          pass: '',
          checkPass: ''
  • 29
    点赞
  • 55
    收藏
    觉得还不错? 一键收藏
  • 21
    评论
评论 21
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值