1. 程式人生 > >人民幣 數字 金額 轉大寫

人民幣 數字 金額 轉大寫


一個html互動的小工具  實現了輸入完數字金額後轉換到大寫的漢字金額 input標籤:
   <input type="number" name="ActualRefundAmount" v-model="tmp.ActualRefundAmount" placeholder="實際退款金額" autocomplete="off" class="layui-input">
   <input type="text" name="ActualRefundCapitalized" v-model="tmp.ActualRefundCapitalized" placeholder="實際退款大寫金額" autocomplete="off" class="layui-input">
轉大寫的正則表示式 做成了方法的形式呼叫:      
1 function DX(n) {//轉大寫     
2 if (!/^(0|[1-9]\d*)(\.\d+)?$/.test(n)) return "資料非法"; 
3 var unit = "千百拾億千百拾萬千百拾元角分", str = ""; 
4 n += "00"; var p = n.indexOf('.'); 
5 if (p >= 0) n = n.substring(0, p) + n.substr(p + 1, 2); 
6 unit = unit.substr(unit.length - n.length);
7  for (var i = 0; i < n.length; i++) str += '零壹貳叄肆伍陸柒捌玖'.charAt(n.charAt(i)) + unit.charAt(i);
8  return str.replace(/零(千|百|拾|角)/g, "零").replace(/(零)+/g, "零").replace(/零(萬|億|元)/g, "$1").replace(/(億)萬|壹(拾)/g, "$1$2").replace(/^元零?|零分/g, "").replace(/元$/g, "元整"); 
9 }      

繫結input標籤的失去焦點事件,也就是輸入完之後:

 1 $("#ActualRefundAmount").on("blur", function (e) {
 2             if (e.delegateTarget.value == "") return;
 3             //獲取input輸入的值
 4             var dx = DX(e.delegateTarget.value);
 5             if (dx == '資料非法') {
 6                 layer.msg("請輸入數字!");
 7                 $("#ActualRefundAmount").val(""); 11                 return;
12             }
13             $("#ActualRefundCapitalized").val(dx); 16         });