人民幣 數字 金額 轉大寫
阿新 • • 發佈:2020-01-07
一個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 });