格式金额,默认保留两位小数,并格式化为千分位

Posted 野猪佩奇007

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了格式金额,默认保留两位小数,并格式化为千分位相关的知识,希望对你有一定的参考价值。

项目场景:

商城类项目中大多需要格式化金额,后缀保留两位小数,并且千元之后加上千分位符号
例子:32,131.00 这种金额,贴上js代码,可以新建一个js引用就行


解决方案:

//格式金额,默认保留两位小数,并格式化为千分位
function formatMoney(number, decimals, dec_point, thousands_sep, roundtag) {
    /*
    * 参数说明:
    * number:要格式化的数字
    * decimals:保留几位小数
    * dec_point:小数点符号
    * thousands_sep:千分位符号
    * roundtag:舍入参数,默认 "ceil" 向上取,"floor"向下取,"round" 四舍五入
    * */
    if (!number) {
        number = 0;
    }
    if (!decimals) {
        decimals = 2;//默认保留2位小数
    }
    if (!dec_point) {
        dec_point = '.';
    }
    if(!thousands_sep){
        thousands_sep = ',';
    }
    if(!roundtag){
        roundtag = 'round';
    }
    number = (number + '').replace(/[^0-9+-Ee.]/g, '');
    roundtag = roundtag || "ceil"; //"ceil","floor","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);

            return '' + parseFloat(Math[roundtag](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);
}

export {
    formatMoney
}

vue中引用使用方法:
main.js:
import * as moneyUtils from “./utils/money”;//引入js
Vue.prototype.moneyUtils = moneyUtils

使用:
this.moneyUtils.formatMoney(Discount)

标签中引用:

{{moneyUtils.formatMoney(Discount)}}

以上是关于格式金额,默认保留两位小数,并格式化为千分位的主要内容,如果未能解决你的问题,请参考以下文章

价格格式化--小数保留两位,整数部分用千分号分割

js实现金额千分位显示

java--数字格式化

将数据格式化为:四舍五入带两位小数点(12.33)

DB2中如果转换数值显示为两位小数,并显示千分位逗号要怎么写SQL?

当使用print语句输出时,Python将所有浮 点数字格式化为小数点后两位。对吗?