Teal TealUI

中国身份证号util/chineseId

解析中国身份证号中的信息。

<input type="text" id="input" placeholder="输入身份证号" value="152500198909267865" />
<button onclick="output.innerHTML = format(parseChineseId(input.value))">校验中国身份证</button>
<div id="output"></div>
<script>
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: "国外"
};
function format(idInfo) {
    return '合法:' + idInfo.valid + 
    '<br>性别:' + (idInfo.sex ? '男' : '女') + 
    '<br>省份:' + (provinces[idInfo.province] || '') + 
    '<br>地级市:' + (idInfo.city || '') + 
    '<br>县级市:' + (idInfo.county || '') + 
    '<br>生日: ' + idInfo.birthday.toLocaleString();
}
</script>
另参考

API

函数 描述
parseChineseId(idNumber)(idNumber:string):object

解析 18 位中国身份证号的信息。

参数 类型 描述 默认值
idNumber* string

返回值

类型:{ valid: boolean; province: number; city: number; county: number; birthday: Date; sex: boolean; }

返回一个对象,包含以下字段:

  • valid:身份证是否合法。
  • province:省份(自治区、直辖市)编码。
  • city:地级市(州、盟)编码。
  • county:县级市(区、旗)编码。
  • birthday:生日。
  • sex:性别。true 表示男, false 表示女。

说明

本函数只验证身份证的数值特征,并不能判定身份证是否真实存在。

示例

parseChineseId("152500198909267865")

解析 18 位中国身份证号的信息。

getAgeFromChineseId(idNumber, ...)(idNumber:string, now?:Date):number

从 18 位身份证号提取周岁。

参数 类型 描述 默认值
idNumber* string
now Date new Date()

返回值

类型:number

返回周岁。如果无法读取身份证号的生日信息则返回 NaN。

示例

getAgeFromChineseId("152500198909267865")

从 18 位身份证号提取周岁。