JS實(shí)現(xiàn)的檢驗(yàn)身份證格式并輸出出生日期,年齡,性別,出生地示例
本文實(shí)例講述了JS實(shí)現(xiàn)的檢驗(yàn)身份證格式并輸出出生日期,年齡,性別,出生地。分享給大家供大家參考,具體如下:
<!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: "澳門(mén)", 91: "國(guó)外" }; //性別 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: '你輸入的身份證長(zhǎng)度或格式錯(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測(cè)試上述代碼,可得如下運(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é)》
希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。
相關(guān)文章
JS 創(chuàng)建對(duì)象的模式實(shí)例小結(jié)
這篇文章主要介紹了JS 創(chuàng)建對(duì)象的模式,結(jié)合實(shí)例形式總結(jié)分析了JS 創(chuàng)建對(duì)象的各種常用模式,包括工廠模式、構(gòu)造函數(shù)模式、原型模式、組合構(gòu)造和原型模式、動(dòng)態(tài)原型模式、寄生構(gòu)造函數(shù)模式、穩(wěn)妥構(gòu)造模式等,需要的朋友可以參考下2020-04-04JavaScript折半查找(二分查找)算法原理與實(shí)現(xiàn)方法示例
這篇文章主要介紹了JavaScript折半查找(二分查找)算法原理與實(shí)現(xiàn)方法,結(jié)合具體問(wèn)題描述了折半查找算法的原理、實(shí)現(xiàn)方法及相關(guān)操作注意事項(xiàng),需要的朋友可以參考下2018-08-08js實(shí)現(xiàn)圖片無(wú)縫滾動(dòng)特效
這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)圖片無(wú)縫循環(huán)滾動(dòng)特效的相關(guān)資料,本實(shí)例在網(wǎng)頁(yè)中較為常見(jiàn),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-01-01在html中引入外部js文件,并調(diào)用帶參函數(shù)的方法
下面小編就為大家?guī)?lái)一篇在html中引入外部js文件,并調(diào)用帶參函數(shù)的方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-10-10layui: layer.open加載窗體時(shí)出現(xiàn)遮罩層的解決方法
今天小編就為大家分享一篇layui: layer.open加載窗體時(shí)出現(xiàn)遮罩層的解決方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-09-09JS組件系列之Bootstrap table表格組件神器【終結(jié)篇】
Bootstrap Table是輕量級(jí)的和功能豐富的以表格的形式顯示的數(shù)據(jù),支持單選,復(fù)選框,排序,分頁(yè),顯示/隱藏列,固定標(biāo)題滾動(dòng)表,響應(yīng)式設(shè)計(jì),Ajax加載JSON數(shù)據(jù),點(diǎn)擊排序的列,卡片視圖等。本文給大家介紹JS組件系列之Bootstrap table表格組件神器【終結(jié)篇】,一起學(xué)習(xí)吧2016-05-05CSS或者JS實(shí)現(xiàn)鼠標(biāo)懸停顯示另一元素
這篇文章主要介紹了CSS或者JS實(shí)現(xiàn)鼠標(biāo)懸停顯示另一元素的相關(guān)資料,需要的朋友可以參考下2016-01-01