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

项目场景:

商城类项目中大多需要格式化金额,后缀保留两位小数,并且千元之后加上千分位符号
例子: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)}}

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

野猪佩奇007

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值