扫的多音字组词?
2022-06-18
更新时间:2023-01-22 07:07:31作者:佚名
身份证号码正则匹配
/^(^[1-9]d{7}((0d)|(1[0-2]))(([0|1|2]d)|3[0-1])d{3}$)|(^[1-9]d{5}[1-9]d{3}((0d)|(1[0-2]))(([0|1|2]d)|3[0-1])((d{4})|d{3}[Xx])$)$/
身份证号码详情解析
以 为例
身份证编码顺序: 32 01 05 51 2 X
32: 第1位~第2位代表所在省(直辖市、自治区)的代码
01: 第3位~第4位代表所在地级市(自治州)的代码
05: 第5位~第6位代表所在区(县、自治县、县级市)的代码
: 第7位~第14位代表出生年、月、日
51: 第15位~第16位代表所在地的派出所的代码
2: 第17位代表性别(注:奇数 => 男 偶数 => 女)
X: 第17位代表个人信息码,不是随计算机的随机产生,它是 用来检验身份证的正确性。(注:校检码可以是0—9的数字,有时也用x表示。作为尾号的校验码,是由号码编制单位按统一的公式计算出来的,如果某人的尾号是0-9身份证后4位查询器,都不会出现X,但如果尾号是10,那么就得用X来代替,因为如果用10做尾号,那么此人的身份证就变成了19位。X是罗马数字的10,用X来代替10身份证后4位查询器,可以保证公民的身份证符合国家标准。)
通过 获取基本信息
以获取 出生日期、年龄、性别、省份为例
const getIdCardInfo = ID => {
const Provinces = {
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: "国外"
};
return {
birthday: ID.substring(6, 14),
age: new Date().getFullYear() - ID.substring(6, 10),
gender: (+ID.substring(16, 17)) % 2 === 1 ? '男' : '女', // 1 => 男 0 => 女
province: Provinces[ID.substring(0, 2)]
}
}
const ID = '411222198409237032';
const info = getIdCardInfo(ID);
console.log(info) // { birthday: '19840923', age: 35, gender: '男', province: '河南' }