js實(shí)現(xiàn)人民幣大寫金額形式轉(zhuǎn)換
本文實(shí)例為大家分享了js實(shí)現(xiàn)金額轉(zhuǎn)大寫的相關(guān)代碼,供大家參考,具體內(nèi)容如下
function convertCurrency(num) { //轉(zhuǎn)成人民幣大寫金額形式 var str1 = '零壹貳叁肆伍陸柒捌玖'; //0-9所對(duì)應(yīng)的漢字 var str2 = '萬(wàn)仟佰拾億仟佰拾萬(wàn)仟佰拾元角分'; //數(shù)字位所對(duì)應(yīng)的漢字 var str3; //從原num值中取出的值 var str4; //數(shù)字的字符串形式 var str5 = ''; //人民幣大寫金額形式 var i; //循環(huán)變量 var j; //num的值乘以100的字符串長(zhǎng)度 var ch1; //數(shù)字的漢語(yǔ)讀法 var ch2; //數(shù)字位的漢字讀法 var nzero = 0; //用來(lái)計(jì)算連續(xù)的零值是幾個(gè) num = Math.abs(num).toFixed(2); //將num取絕對(duì)值并四舍五入取2位小數(shù) str4 = (num * 100).toFixed(0).toString(); //將num乘100并轉(zhuǎn)換成字符串形式 j = str4.length; //找出最高位 if (j > 15) { return '溢出'; } str2 = str2.substr(15 - j); //取出對(duì)應(yīng)位數(shù)的str2的值。如:200.55,j為5所以str2=佰拾元角分 //循環(huán)取出每一位需要轉(zhuǎn)換的值 for (i = 0; i str3 = str4.substr(i, 1); //取出需轉(zhuǎn)換的某一位的值 if (i != (j - 3) && i != (j - 7) && i != (j - 11) && i != (j - 15)) { //當(dāng)所取位數(shù)不為元、萬(wàn)、億、萬(wàn)億上的數(shù)字時(shí) if (str3 == '0') { ch1 = ''; ch2 = ''; nzero = nzero + 1; } else { if (str3 != '0' && nzero != 0) { ch1 = '零' + str1.substr(str3 * 1, 1); ch2 = str2.substr(i, 1); nzero = 0; } else { ch1 = str1.substr(str3 * 1, 1); ch2 = str2.substr(i, 1); nzero = 0; } } } else { //該位是萬(wàn)億,億,萬(wàn),元位等關(guān)鍵位 if (str3 != '0' && nzero != 0) { ch1 = "零" + str1.substr(str3 * 1, 1); ch2 = str2.substr(i, 1); nzero = 0; } else { if (str3 != '0' && nzero == 0) { ch1 = str1.substr(str3 * 1, 1); ch2 = str2.substr(i, 1); nzero = 0; } else { if (str3 == '0' && nzero >= 3) { ch1 = ''; ch2 = ''; nzero = nzero + 1; } else { if (j >= 11) { ch1 = ''; nzero = nzero + 1; } else { ch1 = ''; ch2 = str2.substr(i, 1); nzero = nzero + 1; } } } } } if (i == (j - 11) || i == (j - 3)) { //如果該位是億位或元位,則必須寫上 ch2 = str2.substr(i, 1); } str5 = str5 + ch1 + ch2; if (i == j - 1 && str3 == '0') { //最后一位(分)為0時(shí),加上“整” str5 = str5 + '整'; } } if (num == 0) { str5 = '零元整'; } if (str5.indexOf("分") == -1) { if (str5.indexOf("拾元零") > 0) { str5 = str5.replace("拾元零", "拾元"); }; } return str5; } function doConvert(m, n) { Ext.getCmp(m).on('change', function() { var objm = Ext.getCmp(m); var objn = Ext.getCmp(n); if (!(/^\d+(\.\d+)?$/.test(objm.getValue()))) { objn.setValue(""); } else { var money = convertCurrency(objm.getValue()); if (objm.getValue() == "") { objn.setValue(""); } else { objn.setValue(money); } } var money = convertCurrency(objm.getValue()); if (money.indexOf("拾元零") > 0) { if (money.indexOf("分") == -1) { objn.setValue(money.replace("拾元零", "拾元")); } }; }); }
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家學(xué)習(xí)javascript程序設(shè)計(jì)有所幫助。
- Angular.js 實(shí)現(xiàn)數(shù)字轉(zhuǎn)換漢字實(shí)例代碼
- javascript將數(shù)字轉(zhuǎn)換整數(shù)金額大寫的方法
- js整數(shù)字符串轉(zhuǎn)換為金額類型數(shù)據(jù)(示例代碼)
- JS實(shí)現(xiàn)金額轉(zhuǎn)換(將輸入的阿拉伯?dāng)?shù)字)轉(zhuǎn)換成中文的實(shí)現(xiàn)代碼
- asp.net+js實(shí)現(xiàn)金額格式化
- JS案例分享之金額小寫轉(zhuǎn)大寫
- js 金額格式化來(lái)回轉(zhuǎn)換示例
- js格式化金額可選是否帶千分位以及保留精度
- javascript設(shè)置金額樣式轉(zhuǎn)換保留兩位小數(shù)示例代碼
- JS格式化數(shù)字金額用逗號(hào)隔開(kāi)保留兩位小數(shù)
- JS實(shí)現(xiàn)將數(shù)字金額轉(zhuǎn)換為大寫人民幣漢字的方法
相關(guān)文章
Web性能優(yōu)化系列 10個(gè)提升JavaScript性能的技巧
Javascript 性能優(yōu)化絕不是一種書(shū)面的技術(shù),Nicholas 的技術(shù)演進(jìn)列出了10條建議,幫助你寫出高效的 JS 代碼2016-09-09JS利用?clip-path?實(shí)現(xiàn)動(dòng)態(tài)區(qū)域裁剪功能
這篇文章主要介紹了JS利用?clip-path?實(shí)現(xiàn)動(dòng)態(tài)區(qū)域裁剪功能,文中主要通過(guò)使用 box-shadow 實(shí)現(xiàn),代碼簡(jiǎn)單易懂,對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-12-12微信小程序?qū)崿F(xiàn)表格前后臺(tái)分頁(yè)
這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)表格前后臺(tái)分頁(yè),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-08-0810個(gè)必備的JavaScript?async/await工具函數(shù)分享
當(dāng)談到異步編程時(shí),async/await是JavaScript中常用的功能之一,本文為大家整理了10個(gè)常用的await和async函數(shù)示例,感興趣的小伙伴可以參考一下2023-12-12函數(shù)window.open實(shí)現(xiàn)關(guān)閉所有的子窗口
這篇文章主要介紹了函數(shù)window.open實(shí)現(xiàn)關(guān)閉所有的子窗口的相關(guān)資料,需要的朋友可以參考下。2015-08-08js實(shí)現(xiàn)網(wǎng)頁(yè)隨機(jī)驗(yàn)證碼
這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)網(wǎng)頁(yè)隨機(jī)驗(yàn)證碼,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-10-10TypeScript?Typeof運(yùn)算符的5個(gè)實(shí)用技巧詳解
這篇文章主要為大家介紹了TypeScript?Typeof運(yùn)算符的5個(gè)實(shí)用技巧詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-10-10