身份证号的js校验

 
//这个可以验证15位和18位的身份证,并且包含生日和校验位的验证。  
		//如果有兴趣,还可以加上身份证所在地的验证,就是前6位有些数字合法有些数字不合法。  
		function isIdCardNo(num) {
		    num = num.toUpperCase();
		    //身份证号码为15位或者18位,15位时全为数字,18位前17位为数字,最后一位是校验位,可能为数字或字符X。            
		    if (!(/(^\d{15}$)|(^\d{17}([0-9]|X)$)/.test(num))) {
		         $.jBox.tip("请输入正确身份证号码");
		        $("#idNumber").focus();
		        return false;
		    }
		    //校验位按照ISO 7064:1983.MOD 11-2的规定生成,X可以认为是数字10。 
		    //下面分别分析出生日期和校验位 
		    var len, re;
		    len = num.length;
		    if (len == 15) {
		        re = new RegExp(/^(\d{6})(\d{2})(\d{2})(\d{2})(\d{3})$/);
		        var arrSplit = num.match(re);
		        //检查生日日期是否正确
		        var dtmBirth = new Date('19' + arrSplit[2] + '/' + arrSplit[3] + '/' + arrSplit[4]);
		        var bGoodDay;
		        bGoodDay = (dtmBirth.getYear() == Number(arrSplit[2])) 
		                    && ((dtmBirth.getMonth() + 1) == Number(arrSplit[3])) 
		                    && (dtmBirth.getDate() == Number(arrSplit[4]));
		        if (!bGoodDay) {
		        	 $.jBox.tip("请输入正确身份证号码");
				        $("#idNumber").focus();
		            return false;
		        } else {
		            //将15位身份证转成18位 
		            //校验位按照ISO 7064:1983.MOD 11-2的规定生成,X可以认为是数字10。          
		            var arrInt = new Array(7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2);
		            var arrCh = new Array('1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2');
		            var nTemp = 0, i;
		            num = num.substr(0, 6) + '19' + num.substr(6, num.length - 6);
		            for (i = 0; i < 17; i++) {
		                nTemp += num.substr(i, 1) * arrInt[i];
		            }
		            num += arrCh[nTemp % 11];
		            return num;
		        }
		    }
		    if (len == 18) {
		        re = new RegExp(/^(\d{6})(\d{4})(\d{2})(\d{2})(\d{3})([0-9]|X)$/);
		        var arrSplit = num.match(re);
		        //检查生日日期是否正确 
		        var dtmBirth = new Date(arrSplit[2] + "/" + arrSplit[3] + "/" + arrSplit[4]);
		        var bGoodDay;
		        bGoodDay = (dtmBirth.getFullYear() == Number(arrSplit[2])) 
		                    && ((dtmBirth.getMonth() + 1) == Number(arrSplit[3])) 
		                    && (dtmBirth.getDate() == Number(arrSplit[4]));
		        if (!bGoodDay) {
		        	 $.jBox.tip("请输入正确身份证号码");
				        $("#idNumber").focus();
		            return false;
		        } else {
		            //检验18位身份证的校验码是否正确。 
		            //校验位按照ISO 7064:1983.MOD 11-2的规定生成,X可以认为是数字10。 
		            var valnum;
		            var arrInt = new Array(7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2);
		            var arrCh = new Array('1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2');
		            var nTemp = 0, i;
		            for (i = 0; i < 17; i++) {
		                nTemp += num.substr(i, 1) * arrInt[i];
		            }
		            valnum = arrCh[nTemp % 11];
		            if (valnum != num.substr(17, 1)) {
		            	 $.jBox.tip("请输入正确身份证号码");
		 		        $("#idNumber").focus();
		                return false;
		            }
		            return num;
		        }
		    }
		    return false;
		}
		

如果想加入 jquery校验中

//这个可以验证15位和18位的身份证,并且包含生日和校验位的验证。
//如果有兴趣,还可以加上身份证所在地的验证,就是前6位有些数字合法有些数字不合法。
function idCardValidator(num) {
    if(!num){
        return false;
    }
    num = num.toUpperCase();
    //身份证号码为15位或者18位,15位时全为数字,18位前17位为数字,最后一位是校验位,可能为数字或字符X。
    if (!(/(^\d{15}$)|(^\d{17}([0-9]|X)$)/.test(num))) {
        return false;
    }
    //校验位按照ISO 7064:1983.MOD 11-2的规定生成,X可以认为是数字10。
    //下面分别分析出生日期和校验位
    var len, re;
    len = num.length;
    if (len == 15) {
        re = new RegExp(/^(\d{6})(\d{2})(\d{2})(\d{2})(\d{3})$/);
        var arrSplit = num.match(re);
        //检查生日日期是否正确
        var dtmBirth = new Date('19' + arrSplit[2] + '/' + arrSplit[3] + '/' + arrSplit[4]);
        var bGoodDay;
        bGoodDay = (dtmBirth.getYear() == Number(arrSplit[2]))
            && ((dtmBirth.getMonth() + 1) == Number(arrSplit[3]))
            && (dtmBirth.getDate() == Number(arrSplit[4]));
        if (!bGoodDay) {
            return false;
        } else {
            //将15位身份证转成18位
            //校验位按照ISO 7064:1983.MOD 11-2的规定生成,X可以认为是数字10。
            var arrInt = new Array(7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2);
            var arrCh = new Array('1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2');
            var nTemp = 0, i;
            num = num.substr(0, 6) + '19' + num.substr(6, num.length - 6);
            for (i = 0; i < 17; i++) {
                nTemp += num.substr(i, 1) * arrInt[i];
            }
            num += arrCh[nTemp % 11];
            return true;
        }
    }
    if (len == 18) {
        re = new RegExp(/^(\d{6})(\d{4})(\d{2})(\d{2})(\d{3})([0-9]|X)$/);
        var arrSplit = num.match(re);
        //检查生日日期是否正确
        var dtmBirth = new Date(arrSplit[2] + "/" + arrSplit[3] + "/" + arrSplit[4]);
        var bGoodDay;
        bGoodDay = (dtmBirth.getFullYear() == Number(arrSplit[2]))
            && ((dtmBirth.getMonth() + 1) == Number(arrSplit[3]))
            && (dtmBirth.getDate() == Number(arrSplit[4]));
        if (!bGoodDay) {
            return false;
        } else {
            //检验18位身份证的校验码是否正确。
            //校验位按照ISO 7064:1983.MOD 11-2的规定生成,X可以认为是数字10。
            var valnum;
            var arrInt = new Array(7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2);
            var arrCh = new Array('1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2');
            var nTemp = 0, i;
            for (i = 0; i < 17; i++) {
                nTemp += num.substr(i, 1) * arrInt[i];
            }
            valnum = arrCh[nTemp % 11];
            if (valnum != num.substr(17, 1)) {
                return false;
            }
            return true;
        }
    }
    return true;
}
jQuery.validator.addMethod("idcard", function(b, a) {
    return idCardValidator(b);
}, "身份证号码不正确");







  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 Vue.js 中,可以使用 `rules` 属性来进行表单验证,以下是一个简单的身份证号校验示例: HTML: ``` <template> <div> <el-form :model="form" :rules="rules" ref="form" label-width="80px"> <el-form-item label="身份证号" prop="idNumber"> <el-input v-model="form.idNumber"></el-input> </el-form-item> <el-form-item> <el-button type="primary" @click="submitForm">提交</el-button> </el-form-item> </el-form> </div> </template> ``` Vue.js: ``` <script> export default { data() { return { form: { idNumber: '' }, rules: { idNumber: [ { required: true, message: '请输入身份证号', trigger: 'blur' }, { validator: this.checkIdNumber, trigger: 'blur' } ] } } }, methods: { checkIdNumber(rule, value, callback) { // 身份证号校验 let idNumberReg = /(^\d{15}$)|(^\d{18}$)|(^\d{17}(\d|X|x)$)/; if (!idNumberReg.test(value)) { callback(new Error('身份证号格式不正确!')); } else { callback(); } }, submitForm() { this.$refs.form.validate(valid => { if (valid) { alert('表单验证通过'); } else { alert('表单验证不通过'); return false; } }); } } } </script> ``` 在 `rules` 属性中,我们可以定义一个 `idNumber` 规则,包括两个验证条件: 1. `required`:表示此字段为必填项,如果没有填写内容则会提示 "请输入身份证号"。 2. `validator`:表示使用 `checkIdNumber` 方法进行自定义验证。 在 `checkIdNumber` 方法中,同样使用正则表达式进行身份证号校验,如果校验不通过则通过 `callback` 方法返回错误信息。 在提交表单时,使用 `validate` 方法进行表单验证,如果验证通过则会弹出 "表单验证通过" 的提示框,否则弹出 "表单验证不通过" 的提示框,并且阻止表单提交。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值