提供两种方法:
1. 复杂算法:
/*包含带小数的数字处理,千位加逗号,分位保留,*/
formatNumldy(strNum){
var outputmoney = function (number) {
number = number.replace(/\,/g, ""); //把所有的逗号,清除
if (isNaN(number) || number == "")return "";
number = Math.round(number * 100) / 100;
if (number < 0)
return '-' + outputdollars(Math.floor(Math.abs(number) - 0) + '') + outputcents(Math.abs(number) - 0);
else
return outputdollars(Math.floor(number - 0) + '') + outputcents(number - 0);
}
//格式化金额
var outputdollars = function (number) {
if (number.length <= 3)
return (number == '' ? '0' : number);
else {
var mod = number.length % 3;
var output = (mod == 0 ? '' : (number.substring(0, mod)));
for (i = 0; i < Math.floor(number.length / 3); i++) {
if ((mod == 0) && (i == 0))
output += number.substring(mod + 3 * i, mod + 3 * i + 3);
else
output += ',' + number.substring(mod + 3 * i, mod + 3 * i + 3);
}
return (output);
}
}
var outputcents = function (amount) {
amount = Math.round(((amount) - Math.floor(amount)) * 100);
return (amount < 10 ? '.0' + amount : '.' + amount);
}
return outputmoney(strNum + "");
}
2. 直接使用string字符串的本来属性: toLocaleString()
//语句
parseInt('6451000.3213').toLocaleString();//千位分隔符
//结果
"6,451,000"
这个方法没有保留两位小数,只是单纯的千位分割。
3. 使用Angular.js中的语法:
<div>{{19281|number:2}}</div>
//结果:19,281.00
自动千位分割,且保留两位小数