场景: 传入数字,转换成天数,比如: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使用以及在页面中调用函数