数字转化为大写金额
export const digitUppercase = (n) => {
const fraction = ['角', '分'];
const digit = [
'零', '壹', '贰', '叁', '肆',
'伍', '陆', '柒', '捌', '玖'
];
const unit = [
['元', '万', '亿'],
['', '拾', '佰', '仟']
];
n = Math.abs(n);
let s = '';
for (let i = 0; i < fraction.length; i++) {
s += (digit[Math.floor(n * 10 * Math.pow(10, i)) % 10] + fraction[i]).replace(/零./, '');
}
s = s || '整';
n = Math.floor(n);
for (let i = 0; i < unit[0].length && n > 0; i++) {
let p = '';
for (let j = 0; j < unit[1].length && n > 0; j++) {
p = digit[n % 10] + unit[1][j] + p;
n = Math.floor(n / 10);
}
s = p.replace(/(零.)*零$/, '').replace(/^$/, '零') + unit[0][i] + s;
}
return s.replace(/(零.)*零元/, '元')
.replace(/(零.)+/g, '零')
.replace(/^整$/, '零元整');
};
数字转化为中文数字
export const intToChinese = (value) => {
const str = String(value);
const len = str.length-1;
const idxs = ['','十','百','千','万','十','百','千','亿','十','百','千','万','十','百','千','亿'];
const num = ['零','一','二','三','四','五','六','七','八','九'];
return str.replace(/([1-9]|0+)/g, ( $, $1, idx, full) => {
let pos = 0;
if($1[0] !== '0'){
pos = len-idx;
if(idx == 0 && $1[0] == 1 && idxs[len-idx] == '十'){
return idxs[len-idx];
}
return num[$1[0]] + idxs[len-idx];
} else {
let left = len - idx;
let right = len - idx + $1.length;
if(Math.floor(right / 4) - Math.floor(left / 4) > 0){
pos = left - left % 4;
}
if( pos ){
return idxs[pos] + num[$1[0]];
} else if( idx + $1.length >= len ){
return '';
}else {
return num[$1[0]]
}
}
});
}
以上是编程学习网小编为您介绍的“JavaScript开发小技巧之格式化”的全面内容,想了解更多关于 vuejs 内容,请继续关注编程基础学习网。
织梦狗教程
本文标题为:JavaScript开发小技巧之格式化


基础教程推荐
猜你喜欢
- 基于JavaScript获取url参数2种方法 2024-01-08
- 基于Ajax技术实现文件上传带进度条 2023-01-20
- 网站配色,CSS主色调配色方案 2023-12-30
- JS+CSS实现带有碰撞缓冲效果的竖向导航条代码 2024-01-23
- JavaScript新窗口与子窗口传值详解 2023-12-01
- ZeroClipboard插件实现多浏览器复制功能(支持firefox、chrome、ie6) 2024-02-05
- jquery实现带渐变淡入淡出并向右依次展开的多级菜单效果实例 2024-01-25
- Spring Boot Vue从零开始搭建系统(三):项目前后端分离 2023-10-08
- php-如何在HTML / Javascript的Windows帮助中执行树状结构 2023-10-25
- js取消单选按钮选中示例代码 2023-12-01