JS使用正則控制使用者輸入銀行卡號及格式化

受到鼓舞人發表於2022-03-14

//js正則實現使用者輸入銀行卡號的控制及格式化

<script language="javascript" type="text/javascript">
function formatBankNo (BankNo){
  if (BankNo.value == "") return;
  var account = new String (BankNo.value);
  account = account.substring(0,22); /*帳號的總數, 包括空格在內 */
  if (account.match (".[0-9]{4}-[0-9]{4}-[0-9]{4}-[0-9]{7}") == null){
    /* 對照格式 */
    if (account.match (".[0-9]{4}-[0-9]{4}-[0-9]{4}-[0-9]{7}|" + ".[0-9]{4}-[0-9]{4}-[0-9]{4}-[0-9]{7}|" +
    ".[0-9]{4}-[0-9]{4}-[0-9]{4}-[0-9]{7}|" + ".[0-9]{4}-[0-9]{4}-[0-9]{4}-[0-9]{7}") == null){
      var accountNumeric = accountChar = "", i;
      for (i=0;i<account.length;i++){
        accountChar = account.substr (i,1);
        if (!isNaN (accountChar) && (accountChar != " ")) accountNumeric = accountNumeric + accountChar;
      }
      account = "";
      for (i=0;i<accountNumeric.length;i++){  /* 可將以下空格改為-,效果也不錯 */
        if (i == 4) account = account + " "; /* 帳號第四位數後加空格 */
        if (i == 8) account = account + " "; /* 帳號第八位數後加空格 */
        if (i == 12) account = account + " ";/* 帳號第十二位後數後加空格 */
        account = account + accountNumeric.substr (i,1)
      }
    }
  }
  else
  {
    account = " " + account.substring (1,5) + " " + account.substring (6,10) + " " + account.substring (14,18) + "-" + account.substring(18,25);
  }
  if (account != BankNo.value) BankNo.value = account;
}
</script>
<input type="text" value="" size="25" >

以上所述是小編給大家介紹的JS使用正則控制使用者輸入銀行卡號及格式化,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回覆大家的。

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/70015105/viewspace-2870890/,如需轉載,請註明出處,否則將追究法律責任。

相關文章