JavaScript 金额、数字、千分位、千分位、保留几位小数、舍入舍去、支持负数...

JS数字格式化详解
本文详细介绍了使用JavaScript进行数字格式化的各种方法,包括金额显示、小数位数控制、四舍五入、进一法、去尾法等,同时提供了自定义小数点和千分位分隔符的功能。

 

JavaScript 金额、数字 千分位格式化、保留指定位数小数、支持四舍五入、进一法、去尾法

字段说明:

  number:需要处理的数字;

  decimals:保留几位小数,默认两位,可不传;

  dec_point:小数点符号,默认为‘.’,可不传;

  thousands_sep:千分位符号,默认为‘,’,可不传;

  round_tag:舎入方式,默认为四舍五入('round'),可不传; 向上取值('ceil');向下取值('floor');

 

function decimal_format(number, decimals, dec_point, thousands_sep,round_tag) {
  
    number = (number + '').replace(/[^0-9+-Ee.]/g, '');
	decimals = decimals || 2; //默认保留2位
	dec_point = dec_point || "."; //默认是'.';
	thousands_sep = thousands_sep || ","; //默认是',';
    round_tag = round_tag || "round"; //默认是四舍五入
    var n = !isFinite(+number) ? 0 : +number,
        prec = !isFinite(+decimals) ? 0 : Math.abs(decimals),
        sep = (typeof thousands_sep === 'undefined') ? ',' : thousands_sep,
        dec = (typeof dec_point === 'undefined') ? '.' : dec_point,
        s = '',
        toFixedFix = function (n, prec) {
 
            var k = Math.pow(10, prec);
            console.log();
 
            return '' + parseFloat(Math[round_tag](parseFloat((n * k).toFixed(prec*2))).toFixed(prec*2)) / k;
        };
    s = (prec ? toFixedFix(n, prec) : '' + Math.round(n)).split('.');
    var re = /(-?\d+)(\d{3})/;
    while (re.test(s[0])) {
        s[0] = s[0].replace(re, "$1" + sep + "$2");
    }
    if ((s[1] || '').length < prec) {
        s[1] = s[1] || '';
        s[1] += new Array(prec - s[1].length + 1).join('0');
    }
    return s.join(dec);
}

  执行效果:

console.log(decimal_format(43868.6380))//"43,868.64"
console.log(decimal_format(43868.6380,3))//"43,868.638"
console.log(decimal_format(43868.6380,4,'。')) //"43,868。6380"
console.log(decimal_format(43868.6380,2,".","/"))//"43/868.64"
console.log(decimal_format(-43868.6380))//"-43,868.64"
console.log(decimal_format(43868.6380, 2, ".", ",", "floor")) //"43,868.63"

  

 

转载于:https://www.cnblogs.com/bert227/p/10108223.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值