本文實(shí)例講述了JS實(shí)現(xiàn)的檢驗(yàn)身份證格式并輸出出生日期,年齡,性別,出生地。分享給大家供大家參考,具體如下:
創(chuàng)新互聯(lián)公司長期為成百上千家客戶提供的網(wǎng)站建設(shè)服務(wù),團(tuán)隊(duì)從業(yè)經(jīng)驗(yàn)10年,關(guān)注不同地域、不同群體,并針對不同對象提供差異化的產(chǎn)品和服務(wù);打造開放共贏平臺(tái),與合作伙伴共同營造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為丁青企業(yè)提供專業(yè)的成都做網(wǎng)站、網(wǎng)站制作,丁青網(wǎng)站改版等技術(shù)服務(wù)。擁有十年豐富建站經(jīng)驗(yàn)和眾多成功案例,為您定制開發(fā)。
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>檢驗(yàn)身份證格式并輸出出生日期,年齡,性別,出生地</title>
</head>
<body>
<script>
window.onload = function() {
var txtVal = document.getElementById("txtVal");
var oBtn = document.getElementById("oBtn");
//兼容瀏覽器點(diǎn)擊事件
function myAddEvent(obj, ev, fn) {
if(obj.attachEvent) {
obj.attachEvent("on" + ev, fn);
}
else {
obj.addEventListener(ev, fn, false);
}
};
//身份證地區(qū)
var areaID = {
11: "北京",
12: "天津",
13: "河北",
14: "山西",
15: "內(nèi)蒙古",
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: "臺(tái)灣",
81: "香港",
82: "澳門",
91: "國外"
};
//性別
var sexMap = {0: "女", 1: "男"};
/*********************************************
* 檢驗(yàn)身份證格式是否正確
********************************************/
var checkIdCard = function(IDCard) {
var iSum = 0;
var info = "";
if(!/^\d{17}(\d|x)$/i.test(IDCard))
return {
status: false,
message: '你輸入的身份證長度或格式錯(cuò)誤!'
};
IDCard = IDCard.replace(/x$/i, "a");
if(areaID[parseInt(IDCard.substr(0, 2))] == null)
return {
status: false,
message: '你的身份證地區(qū)非法!'
};
var sBirthday = IDCard.substr(6, 4) + "-" + Number(IDCard.substr(10, 2)) + "-" + Number(IDCard.substr(12, 2));
var d = new Date(sBirthday.replace(/-/g, "/"));
if(sBirthday != (d.getFullYear() + "-" + (d.getMonth() + 1) + "-" + d.getDate()))
return {
status: false,
message: '身份證上的出生日期非法!'
};
for(var i = 17; i >= 0; i--)
iSum += (Math.pow(2, i) % 11) * parseInt(IDCard.charAt(17 - i), 11);
if(iSum % 11 != 1)
return {
status: false,
message: '你輸入的身份證號(hào)非法!'
};
//aCity[parseInt(sId.substr(0,2))]+","+sBirthday+","+(sId.substr(16,1)%2?"男":"女");//此次還可以判斷出輸入的身份證號(hào)的人性別
return {
status: true,
message: '校驗(yàn)成功!'
};
};
/*********************************************
* 根據(jù)身份證號(hào)獲取性別
*********************************************/
var getSexByIdCard = function(idCard) {
if(idCard.length == 15) {
return sexMap[idCard.substring(14, 15) % 2];
} else if(idCard.length == 18) {
return sexMap[idCard.substring(14, 17) % 2];
} else {
//不是15或者18,null
return '';
}
};
/*********************************************
* 根據(jù)身份證號(hào)獲取生日
*********************************************/
var getBirthdayByIdCard = function(idCard) {
var birthStr;
if(15 == idCard.length) {
birthStr = idCard.charAt(6) + idCard.charAt(7);
if(parseInt(birthStr) < 10) {
birthStr = '20' + birthStr;
} else {
birthStr = '19' + birthStr;
}
birthStr = birthStr + '-' + idCard.charAt(8) + idCard.charAt(9) + '-' + idCard.charAt(10) + idCard.charAt(11);
} else if(18 == idCard.length) {
birthStr = idCard.charAt(6) + idCard.charAt(7) + idCard.charAt(8) + idCard.charAt(9) + '-' + idCard.charAt(10) + idCard.charAt(11) + '-' + idCard.charAt(12) + idCard.charAt(13);
}
return birthStr;
};
/*********************************************
* 根據(jù)身份證號(hào)獲取出生地
*********************************************/
var getAreaByIdCard = function(idCard) {
return areaID[parseInt(idCard.substr(0, 2))];
};
/*********************************************
* 根據(jù)身份證號(hào)獲取年齡
*********************************************/
var getAgeByIdCard = function(idCard) {
var birthStr = getBirthdayByIdCard(idCard);
var r = birthStr.match(/^(\d{1,4})(-|\/)(\d{1,2})\2(\d{1,2})$/);
if(r == null) return '';
var d = new Date(r[1], r[3] - 1, r[4]);
if(d.getFullYear() == r[1] && (d.getMonth() + 1) == r[3] && d.getDate() == r[4]) {
var Y = new Date().getFullYear();
return (Y - r[1]);
} else {
return '';
}
};
//點(diǎn)擊獲取校驗(yàn)結(jié)果
myAddEvent(oBtn, "click", function() {
var card = txtVal.value
if(checkIdCard(card).status) {
//校驗(yàn)是否成功
console.log(checkIdCard(card).message)
//輸出性別
console.log(getSexByIdCard(card))
//輸出生日
console.log(getBirthdayByIdCard(card))
//輸出出生地
console.log(getAreaByIdCard(card))
//輸出年齡
console.log(getAgeByIdCard(card))
} else {
console.log(checkIdCard(card).message)
}
});
}
</script>
<input type="text" value="" id="txtVal">
<input type="button" id="oBtn" value="獲取身份證信息">
</body>
</html>
這里使用在線HTML/CSS/JavaScript代碼運(yùn)行工具:http://tools.jb51.net/code/HtmlJsRun測試上述代碼,可得如下運(yùn)行結(jié)果:

另外,本站在線工具小程序上也有一款功能更加強(qiáng)大的身份證信息獲取工具,感興趣的朋友可以掃描如下小程序碼查看:

更多關(guān)于JavaScript相關(guān)內(nèi)容還可查看本站專題:《JavaScript正則表達(dá)式技巧大全》、《JavaScript替換操作技巧總結(jié)》、《JavaScript查找算法技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》、《JavaScript中json操作技巧總結(jié)》、《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》及《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)》
希望本文所述對大家JavaScript程序設(shè)計(jì)有所幫助。
新聞名稱:JS實(shí)現(xiàn)的檢驗(yàn)身份證格式并輸出出生日期,年齡,性別,出生地示例
文章分享:http://www.chinadenli.net/article2/piioic.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供移動(dòng)網(wǎng)站建設(shè)、微信公眾號(hào)、關(guān)鍵詞優(yōu)化、營銷型網(wǎng)站建設(shè)、做網(wǎng)站、品牌網(wǎng)站設(shè)計(jì)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)