利用身份证验证性别和获取生日

通过身份证号码验证性别和获取生日的方法如下:

身份证号码的17位代表性别,奇数代表男性,偶数代表女性。
身份证号码的18位数字的7-10位代表出生年份,格式为YYYY
11-12位:出生月份,格式为MM
13-14位:出生日,格式为DD
根据这个规则,我们可以编写一个程序来验证性别和获取生日。

1.HTML部分
首先在页面上设置三个input输入框,分别放置身份证号码、性别和出生日期

<body>
		<!-- 身份证号码输入框 -->
		<input type="text" placeholder="请输入身份证号码" />
		<!-- 性别输入框 -->
		<input type="text" placeholder="输入身份证号码自动填充" />
		<!-- 出生日期选择框 -->
		<input type="date" placeholder="输入身份证号码自动填充" />
	</body>

然后给身份证输入框绑定oninput事件

<body>
		<!-- 身份证号码输入框 -->
		<input type="text" placeholder="请输入身份证号码" id="sfzh" oninput="sfzh()" />
		<!-- 性别输入框 -->
		<input type="text" placeholder="输入身份证号码自动填充" id="xingbie" />
		<!-- 出生日期选择框 -->
		<input type="date" placeholder="输入身份证号码自动填充" id="birthday" />
	</body>

2.JS部分

然后在JS中设置身份证的oninput事件

首先声明一个正则表达式

let reg = /^[1-9]\d{5}(19|20)\d{2}((0[1-9])|(1[0-2]))(([0-2][1-9])|10|20|30|31)\d{3}[0-9xX]$/

这个正则表达式可以匹配一个身份证号码,并验证其格式是否正确。

这个正则表达式中:

/^[1-9]\d{5}/ 匹配以 1-9 的数字开头的 6 位数字。
/((19|20)\d{2})/ 匹配 19 或 20 的 4 位年份。
/((0[1-9])|(1[0-2]))/ 匹配 01-12 的月份。
/(([0-2][1-9])|10|20|30|31)/ 匹配 01-31 的日期。
/d{3}/ 匹配 3 位顺序码。
/[0-9xX]/ 匹配校验码,可以是数字或 X。
然后再声明一个变量来获取到身份证输入框里的值

let idcard = document.getElementById('sfzh').value

再判断如果身份证输入框里的值不符合正则表达式,则出现不符合格式提示,性别和生日输入框的值也为空

// 如果不符合正则表达式
				}else if(!reg.test(idcard)){
					// 显示身份证号、性别、出生日期提示框,并且生日和性别的输入框值为空
					$(".sfzh").text("证件号码格式不正确").css("display", "block");
					$("#xingbie").val("");
					$("#birthday").val("");
					$(".xingbie").show();
					$(".birthday").show();
				}

再判断输入框的值符合正则表达式时,隐藏提示文本:

// 如果符合正则表达式
				if (reg.test(idcard)) {
					// 隐藏身份证提示文本
					$(".sfzh").css("display", "none");
					// 隐藏性别提示文本
					$('.xingbie').hide();
					// 隐藏生日提示文本
					$('.birthday').hide();
				}

substring用来截取字符串的函数,起始索引(包括)和结束索引(不包括),有两个参数,从起始索引开始截取,直到但不包括结束索引。

声明一个变量等于身份证号从第16截取到第17位的字符串并转换成整形。

声明一个变量等于身份证号从第16截取到第17位的字符串并转换成整形。

// 获取截取身份证号第16-17位的字符串
                    let genderCode = parseInt(idcard.substring(16, 17));
声明一个变量等于身份证号从第6位截取到第10位的字符串

// 获取截取身份证号第6-10位的字符串
                    let birthYear = idcard.substring(6, 10);
声明一个变量等于身份证号从第10位截取到第12位的字符串

// 获取截取身份证号第10-12位的字符串
                    let birthMonth = idcard.substring(10, 12);
声明一个变量等于身份证号从第12位截取到第14位的字符串

// 获取截取身份证号第12-14位的字符串
                    let birthDay = idcard.substring(12, 14);
控制台输出出生年月日

// 控制台输出出生日期
                    console.log(birthYear, birthMonth, birthDay)

  • 5
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
自己写的比较全js验证,供大家参考 //身份证验证 function checkIdcard(idcard1,showMsg){ var idcard=this.trim(idcard1);// 对身份证号码做处理。去除头尾空格。 var Errors=new Array( "验证通过!", "身份证号码位数不对!", "身份证号码出生日期超出范围或含有非法字符!", "身份证号码校验错误!", "身份证地区非法!" ); var area={11:"北京",12:"天津",13:"河北",14:"山西",15:"内蒙古",21:"辽宁",22:"吉林",23:"黑龙江",31:"上海",32:"江苏",33:"浙江",34:"安徽",35:"福建",36:"江西",37:"山东",41:"河南",42:"湖北",43:"湖南",44:"广东",45:"广西",46:"海南",50:"重庆",51:"四川",52:"贵州",53:"云南",54:"西藏",61:"陕西",62:"甘肃",63:"青海",64:"宁夏",65:"新疆",71:"台湾",81:"香港",82:"澳门",91:"国外"} var idcard,Y,JYM; var S,M; var idcard_array = new Array(); idcard_array = idcard.split(""); /*基本校验*/ if(idcard == "" || idcard == null || idcard.length == 0) { if(showMsg==null||showMsg=="") alert("身份证号为空,请输入您的身份证号!"); return false; } /*地区检验*/ if(area[parseInt(idcard.substr(0,2))]==null) { if(showMsg==null||showMsg=="") alert(Errors[4]); return false; } /*身份号码位数及格式检验*/ switch(idcard.length){ case 15: if ( (parseInt(idcard.substr(6,2))+1900) % 4 == 0 || ((parseInt(idcard.substr(6,2))+1900) % 100 == 0 && (parseInt(idcard.substr(6,2))+1900) % 4 == 0 )){ ereg=/^[1-9][0-9]{5}[0-9]{2}((01|03|05|07|08|10|12)(0[1-9]|[1-2][0-9]|3[0-1])|(04|06|09|11)(0[1-9]|[1-2][0-9]|30)|02(0[1-9]|[1-2][0-9]))[0-9]{3}$/;//测试出生日期的合法性 } else { ereg=/^[1-9][0-9]{5}[0-9]{2}((01|03|05|07|08|10|12)(0[1-9]|[1-2][0-9]|3[0-1])|(04|06|09|11)(0[1-9]|[1-2][0-9]|30)|02(0[1-9]|1[0-9]|2[0-8]))[0-9]{3}$/;//测试出生日期的合法性 } if(ereg.test(idcard)){ //alert(Errors[0]+"15"); return true; //15位验证通过 } else { if(showMsg==null||showMsg=="") alert(Errors[2]); return false; } break; case 18: //18位身份号码检测 //出生日期的合法性检查 //闰年月日:((01|03|05|07|08|10|12)(0[1-9]|[1-2][0-9]|3[0-1])|(04|06
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值