欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

js實現(xiàn)身份證號碼驗證的簡單實例

 更新時間:2014年02月19日 10:02:57   作者:  
本篇文章主要是對js實現(xiàn)身份證號碼驗證的簡單實例進行了介紹,需要的朋友可以過來參考下,希望對大家有所幫助

以下是根據(jù)身份證號碼編碼規(guī)則,使用JS對其進行有效性驗證代碼

IdCard-Validate.js代碼如下:

復制代碼 代碼如下:

/**
 * 身份證15位編碼規(guī)則:dddddd yymmdd xx p
 * dddddd:地區(qū)碼
 * yymmdd: 出生年月日
 * xx: 順序類編碼,無法確定
 * p: 性別,奇數(shù)為男,偶數(shù)為女
 * <p />
 * 身份證18位編碼規(guī)則:dddddd yyyymmdd xxx y
 * dddddd:地區(qū)碼
 * yyyymmdd: 出生年月日
 * xxx:順序類編碼,無法確定,奇數(shù)為男,偶數(shù)為女
 * y: 校驗碼,該位數(shù)值可通過前17位計算獲得
 * <p />
 * 18位號碼加權因子為(從右到左) Wi = [ 7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2,1 ]
 * 驗證位 Y = [ 1, 0, 10, 9, 8, 7, 6, 5, 4, 3, 2 ]
 * 校驗位計算公式:Y_P = mod( ∑(Ai×Wi),11 )
 * i為身份證號碼從右往左數(shù)的 2...18 位; Y_P為腳丫校驗碼所在校驗碼數(shù)組位置
 *
 */

var Wi = [ 7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2, 1 ];// 加權因子
var ValideCode = [ 1, 0, 10, 9, 8, 7, 6, 5, 4, 3, 2 ];// 身份證驗證位值.10代表X
function IdCardValidate(idCard) {
 idCard = trim(idCard.replace(/ /g, ""));
 if (idCard.length == 15) {
  return isValidityBrithBy15IdCard(idCard);
 } else if (idCard.length == 18) {
  var a_idCard = idCard.split("");// 得到身份證數(shù)組
  if(isValidityBrithBy18IdCard(idCard)&&isTrueValidateCodeBy18IdCard(a_idCard)){
   return true;
  }else {
   return false;
  }
 } else {
  return false;
 }
}
/**
 * 判斷身份證號碼為18位時最后的驗證位是否正確
 * @param a_idCard 身份證號碼數(shù)組
 * @return
 */
function isTrueValidateCodeBy18IdCard(a_idCard) {
 var sum = 0; // 聲明加權求和變量
 if (a_idCard[17].toLowerCase() == 'x') {
  a_idCard[17] = 10;// 將最后位為x的驗證碼替換為10方便后續(xù)操作
 }
 for ( var i = 0; i < 17; i++) {
  sum += Wi[i] * a_idCard[i];// 加權求和
 }
 valCodePosition = sum % 11;// 得到驗證碼所位置
 if (a_idCard[17] == ValideCode[valCodePosition]) {
  return true;
 } else {
  return false;
 }
}
/**
 * 通過身份證判斷是男是女
 * @param idCard 15/18位身份證號碼
 * @return 'female'-女、'male'-男
 */
function maleOrFemalByIdCard(idCard){
 idCard = trim(idCard.replace(/ /g, ""));// 對身份證號碼做處理。包括字符間有空格。
 if(idCard.length==15){
  if(idCard.substring(14,15)%2==0){
   return 'female';
  }else{
   return 'male';
  }
 }else if(idCard.length ==18){
  if(idCard.substring(14,17)%2==0){
   return 'female';
  }else{
   return 'male';
  }
 }else{
  return null;
 }
// 可對傳入字符直接當作數(shù)組來處理
// if(idCard.length==15){
// alert(idCard[13]);
// if(idCard[13]%2==0){
// return 'female';
// }else{
// return 'male';
// }
// }else if(idCard.length==18){
// alert(idCard[16]);
// if(idCard[16]%2==0){
// return 'female';
// }else{
// return 'male';
// }
// }else{
// return null;
// }
}
 /**
  * 驗證18位數(shù)身份證號碼中的生日是否是有效生日
  * @param idCard 18位書身份證字符串
  * @return
  */
function isValidityBrithBy18IdCard(idCard18){
 var year =  idCard18.substring(6,10);
 var month = idCard18.substring(10,12);
 var day = idCard18.substring(12,14);
 var temp_date = new Date(year,parseFloat(month)-1,parseFloat(day));
 // 這里用getFullYear()獲取年份,避免千年蟲問題
 if(temp_date.getFullYear()!=parseFloat(year)
       ||temp_date.getMonth()!=parseFloat(month)-1
       ||temp_date.getDate()!=parseFloat(day)){
        return false;
 }else{
  return true;
 }
}
  /**
   * 驗證15位數(shù)身份證號碼中的生日是否是有效生日
   * @param idCard15 15位書身份證字符串
   * @return
   */
  function isValidityBrithBy15IdCard(idCard15){
   var year =  idCard15.substring(6,8);
   var month = idCard15.substring(8,10);
   var day = idCard15.substring(10,12);
   var temp_date = new Date(year,parseFloat(month)-1,parseFloat(day));
   // 對于老身份證中的你年齡則不需考慮千年蟲問題而使用getYear()方法
   if(temp_date.getYear()!=parseFloat(year)
        ||temp_date.getMonth()!=parseFloat(month)-1
        ||temp_date.getDate()!=parseFloat(day)){
         return false;
  }else{
   return true;
  }
  }
//去掉字符串頭尾空格
function trim(str) {
 return str.replace(/(^/s*)|(/s*$)/g, "");
}


對于上述代碼中,關于性別的判斷在實際使用中,可加入首先判斷身份證是否有效。在本代碼示例中并未進行該種判斷,有點雞肋的感覺,可在實際使用中根據(jù)情況進行豐滿。

相關文章

  • 在JavaScript中模擬類(class)及類的繼承關系

    在JavaScript中模擬類(class)及類的繼承關系

    眾所周知,JavaScript中沒有類,然而我們卻可以動手實現(xiàn)一個擁有繼承特性的類,所以接下來我們要討論的便是在JavaScript中模擬類(class)及類的繼承關系:
    2016-05-05
  • 判斷顏色是否合法的正則表達式(詳解)

    判斷顏色是否合法的正則表達式(詳解)

    下面小編就為大家?guī)硪黄袛囝伾欠窈戏ǖ恼齽t表達式(詳解)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-05-05
  • 利用JS實現(xiàn)一個同Excel表現(xiàn)的智能填充算法

    利用JS實現(xiàn)一個同Excel表現(xiàn)的智能填充算法

    這篇文章主要給大家介紹了關于利用JS實現(xiàn)一個同Excel表現(xiàn)的智能填充算法的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2018-08-08
  • iframe實用操作錦集

    iframe實用操作錦集

    這篇文章主要介紹了有關iframe的實用操作,包括高度、傳遞數(shù)據(jù)等等,感興趣的朋友可以參考下
    2014-04-04
  • 純JS實現(xiàn)五子棋游戲

    純JS實現(xiàn)五子棋游戲

    這篇文章主要為大家詳細介紹了純JS實現(xiàn)五子棋游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-05-05
  • JS獲取子節(jié)點、父節(jié)點和兄弟節(jié)點的方法實例總結(jié)

    JS獲取子節(jié)點、父節(jié)點和兄弟節(jié)點的方法實例總結(jié)

    這篇文章主要介紹了JS獲取子節(jié)點、父節(jié)點和兄弟節(jié)點的方法,結(jié)合實例形式總結(jié)分析了JavaScript針對子節(jié)點、父節(jié)點和兄弟節(jié)點獲取相關操作技巧與使用注意事項,需要的朋友可以參考下
    2018-07-07
  • js強制把網(wǎng)址設為默認首頁

    js強制把網(wǎng)址設為默認首頁

    有時候你會發(fā)現(xiàn)設首頁為失效,那么來一個js強制設置首頁的代碼,不過為了綠色上網(wǎng),盡量不要強迫你的用戶意志,弄不好網(wǎng)站用戶體驗會降低。感興趣的小伙伴可以參考一下
    2015-09-09
  • 使用canvas實現(xiàn)仿新浪微博頭像截取上傳功能

    使用canvas實現(xiàn)仿新浪微博頭像截取上傳功能

    用戶提供圖像大小尺寸不合適,如何用截取上傳呢?接下來小編教大家使用使用canvas實現(xiàn)仿新浪微博頭像截取上傳功能解決問題,需要的朋友一起學習吧。
    2015-09-09
  • 詳解javascript遍歷方式

    詳解javascript遍歷方式

    這篇文章主要介紹了詳解javascript遍歷方式,感興趣的小伙伴們可以參考一下
    2015-11-11
  • 在js文件中寫el表達式取不到值的原因及解決方法

    在js文件中寫el表達式取不到值的原因及解決方法

    在js文件中寫el表達式取不到值,百度一下,將經(jīng)驗總結(jié)如下,有類似情況的朋友可以參考下
    2013-12-12

最新評論