场景: 传入数字,转换成天数,比方:index = 1
转换后则为 一
,在页面中的利用就是<view> 第{{index}} 天 </view>
,转为第几天。
<view> 第 {{exchange.exChangeNum(index)}} 天 </view>
<wxs module="exchange">
/**
* 将数字(整数)转为汉字
* @param num
* @description 从零到一亿亿,须要小数的可自行截取小数点前面的数字间接替换对应 arr1 的读法就行了
*/
var exChangeNum = function (num) {var arr1 = ['零', '一', '二', '三', '四', '五', '六', '七', '八', '九'];
var arr2 = ['',' 十 ',' 百 ',' 千 ',' 万 ',' 十 ',' 百 ',' 千 ',' 亿 ',' 十 ',' 百 ',' 千 ',' 万 ',' 十 ',' 百 ',' 千 ',' 亿 '];// 可持续追加更高位转换值
if (!num || isNaN(num)) {return "零";}
var english = num.toString().split("");
var result = "";
for (var i = 0; i < english.length; i++) {
var des_i = english.length - 1 - i; // 倒序排列设值
result = arr2[i] + result;
var arr1_index = english[des_i];
result = arr1[+arr1_index] + result;
}
// 将【零千、零百】换成【零】【十零】换成【十】result = result.replace(getRegExp('零(千 | 百 | 十)', 'g'), '零').replace(getRegExp('十零', 'g'), '十');
// 合并两头多个零为一个零
result = result.replace(getRegExp('零 +', 'g'), '零');
// 将【零亿】换成【亿】【零万】换成【万】result = result.replace(getRegExp('零亿', 'g'), '亿').replace(getRegExp('零万', 'g'), '万');
// 将【亿万】换成【亿】result = result.replace(getRegExp('亿万', 'g'), '亿');
// 移除开端的零
result = result.replace(getRegExp('零 +$'), '');
// 将【零一十】换成【零十】//result = result.replace(/ 零一十 /g, '零十');// 貌似正规读法是零一十
// 将【一十】换成【十】result = result.replace(getRegExp('^ 一十', 'g'), '十');
return result;
}
module.exports.exChangeNum = exChangeNum;
</wxs>
对于 wsx 的应用请看:微信小程序 wxs 应用以及在页面中调用函数