資料載入中

我是 chung

鎖住記憶

  • Chung
  • 0°C
  • 8 年又 244 天

如何使用javascript判斷身分證號跟居留證格式

首先,是把如何用javascript判斷字串中必須包含中英文的方式延伸~

將每一個字轉換成 ASCII 碼。

在使用for迴圈去檢查每個字是不是在  65-90(a-z) 的範圍。
var text='A12345678';
var res = text.toUpperCase(); //將字母由小寫變大寫

var check=[];
check['alpha']=0;
for(var i=0;i[2;i++){
var t=res.charCodeAt(i);

if(t]=65 && t[=90){
check['alpha']++;
}}

因為身分證的第一個字是英文字母,而居留證則是前二個字是英文字母。

因此底下可以先做最基本的判斷,得到的ID是屬於身分證還是居留證~
if(check['alpha']==2){
if (!check_resident_ID(res)){
alert(res+"此居留證字號錯誤、少碼或空格,請確認後重新輸入。")
exit();
}

}else if(check['alpha']==1){
if (!checkID(res)){
alert(res+"此身分證字號錯誤、少碼或空格,請確認後重新輸入。")
exit();
}

}else{
alert('ID錯誤');
}

接著身分證部分的檢查function如下~
function checkID( id ) {
//alert(id)
tab = "ABCDEFGHJKLMNPQRSTUVXYWZIO"
A1 = new Array (1,1,1,1,1,1,1,1,1,1,2,2,2,2,2,2,2,2,2,2,3,3,3,3,3,3 );
A2 = new Array (0,1,2,3,4,5,6,7,8,9,0,1,2,3,4,5,6,7,8,9,0,1,2,3,4,5 );
Mx = new Array (9,8,7,6,5,4,3,2,1,1);

//驗證填入身分證字號長度及格式
if ( id.length != 10 ) return false;
i = tab.indexOf( id.charAt(0) );
if ( i == -1 ) return false;
sum = A1[i] + A2[i]*9;

for ( i=1; i[10; i++ ) {
v = parseInt( id.charAt(i) );
if ( isNaN(v) ) return false;
sum = sum + v * Mx[i];
}
if ( sum % 10 != 0 ) return false;
return true;
}

居留證的檢查function如下~
function check_resident_ID( id ) {

//驗證填入身分證字號長度及格式
if(id.length != 10){
return false;
}

//格式,用正則表示式比對第一個字母是否為英文字母
if(isNaN(id.substr(2,8)) ||
(!/^[A-Z]$/.test(id.substr(0,1))) || (!/^[A-Z]$/.test(id.substr(1,1)))){
return false;
}

var idHeader = "ABCDEFGHJKLMNPQRSTUVXYWZIO"; //按照轉換後權數的大小進行排序
//這邊把身分證字號轉換成準備要對應的
id = (idHeader.indexOf(id.substring(0,1))+10) +
'' + ((idHeader.indexOf(id.substr(1,1))+10) % 10) + '' + id.substr(2,8);
//開始進行身分證數字的相乘與累加,依照順序乘上1987654321

snumber = parseInt(id.substr(0,1)) +
parseInt(id.substr(1,1)) * 9 +
parseInt(id.substr(2,1)) * 8 +
parseInt(id.substr(3,1)) * 7 +
parseInt(id.substr(4,1)) * 6 +
parseInt(id.substr(5,1)) * 5 +
parseInt(id.substr(6,1)) * 4 +
parseInt(id.substr(7,1)) * 3 +
parseInt(id.substr(8,1)) * 2 +
parseInt(id.substr(9,1));

checkNum = parseInt(id.substr(10,1));
//模數 - 總和/模數(10)之餘數若等於第九碼的檢查碼,則驗證成功

console.log(10 - snumber % 10);
if((10 - snumber % 10) == checkNum){
return true;
}
else{
return false;
}

}

以上紀錄~

台北市內湖區江南街71巷75弄 Go

  • javascript 判斷字串中包含中英文
  • 身分證與居留證的字母檢查
  • ASCII 碼轉換與字元範圍
  • 使用 for 迴圈檢查字元
  • 身分證和居留證的基本判斷方法
https://innstory.com/story-如何使用javascript判斷身分證號跟居留證格式-1267

上一篇
 如何用javascript判斷字串中必須包含中英文

下一篇
小老虎探險 

發表留言

作者簡介

我是chung,網路工作者

主業是網站系統開發建置
副業是做夢、紀錄故事
作品請參考:teme.biz
做夢請參考:innstory.com
聯絡:chung.teme@gmail.com

有人用筆寫日記,有人用歲月寫日記,有人用照片寫日記,而我,用innstory寫日記。


推薦閱讀

作者其他相關類別故事

php函式紀錄

php函式紀錄

Chung 10 年又 123 天 1.9K

常常忘記,只得紀錄下來......

PHP如何將陣列組合接成字串

PHP如何將陣列組合接成字串

Chung 10 年又 13 天 1.8K

上列範例得到的結果是 hello word PHP join 函數的功能是可以把 PHP Arr...

Android Studio 2.3 陽春型計算機

Android Studio…

Chung 8 年又 319 天 4.3K

原本這次的學習課題是,與使用者互動之「按一下」事件處理。 我按照工具書上寫的,完成了按一下But...


推薦閱讀

這個地址也發生了其他故事

傳聲筒,還好小時候有上過自然科學。

傳聲筒,還好小時候有上過自然…

Chung 7 年又 28 天 1.6K

用吃完的優格杯子自製了傳聲筒。 我跟5U玩的不亦樂乎。 當然我小學的記憶是養樂多瓶子加上牙籤,但...

5G看起來好像有美人尖哩

5G看起來好像有美人尖哩

Chung 7 年又 27 天 1.7K

5G看起來好像有美人尖哩~

還好我們生了兩個孩子

還好我們生了兩個孩子

Chung 7 年又 27 天 1.5K

我知道,照顧兩個孩子真的是讓人疲於奔命。 但看著他們成長的確也是讓人開心。 梧悠、梧綠,希望你們...


附近景點

這個地址-台北市內湖區江南街71巷75弄-附近還有甚麼?

  • 國立臺灣大學日式宿舍─馬廷英故居
  • 圓山別莊
  • 草山御賓館
  • 台北霞海城隍廟
  • 艋舺地藏庵
  • 南海學園科學館