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