js格式化数字为金额

 1 /**
 2  *
 3  * @param num
 4  * @param precision
 5  * @param separator
 6  * @returns {*}
 7  *=======================================================
 8  *     formatNumber(10000)="10,000"
 9  *     formatNumber(10000, 2)="10,000.00"
10  *     formatNumber(10000.123456, 2)="10,000.12"
11  *     formatNumber(10000.123456, 2, ' ')="10 000.12"
12  *     formatNumber(.123456, 2, ' ')="0.12"
13  *     formatNumber(56., 2, ' ')="56.00"
14  *     formatNumber(56., 0, ' ')="56"
15  *     formatNumber('56.')="56"
16  *     formatNumber('56.a')=NaN
17  *=======================================================
18  */
19 function formatNumber(num, precision, separator) {
20     var parts;
21     // 判断是否为数字
22     if (!isNaN(parseFloat(num)) && isFinite(num)) {
23         // 把类似 .5, 5. 之类的数据转化成0.5, 5, 为数据精度处理做准, 至于为什么
24         // 不在判断中直接写 if (!isNaN(num = parseFloat(num)) && isFinite(num))
25         // 是因为parseFloat有一个奇怪的精度问题, 比如 parseFloat(12312312.1234567119)
26         // 的值变成了 12312312.123456713
27         num = Number(num);
28         // 处理小数点位数
29         num = (typeof precision !== 'undefined' ? num.toFixed(precision) : num).toString();
30         // 分离数字的小数部分和整数部分
31         parts = num.split('.');
32         // 整数部分加[separator]分隔, 借用一个著名的正则表达式
33         parts[0] = parts[0].toString().replace(/(\d)(?=(\d{3})+(?!\d))/g, '$1' + (separator || ','));
34 
35         return parts.join('.');
36     }
37     return NaN;
38 }
39 
40 
41 /**
42  * 把数字转换成货币的格式
43  * @param decimals
44  * @param dec_point
45  * @param thousands_sep
46  * @returns {string}
47  */
48 Number.prototype.format=function(decimals, dec_point, thousands_sep){
49     var num = (this + '')
50         .replace(/[^0-9+\-Ee.]/g, '');
51     var n = !isFinite(+num) ? 0 : +num,
52         prec = !isFinite(+decimals) ? 0 : Math.abs(decimals),
53         sep = (typeof thousands_sep === 'undefined') ? ',' : thousands_sep,
54         dec = (typeof dec_point === 'undefined') ? '.' : dec_point,
55         s = '',
56         toFixedFix = function(n, prec) {
57             var k = Math.pow(10, prec);
58             return '' + (Math.round(n * k) / k)
59                     .toFixed(prec);
60         };
61     // Fix for IE parseFloat(0.55).toFixed(0) = 0;
62     s = (prec ? toFixedFix(n, prec) : '' + Math.round(n))
63         .split('.');
64     if (s[0].length > 3) {
65         s[0] = s[0].replace(/\B(?=(?:\d{3})+(?!\d))/g, sep);
66     }
67     if ((s[1] || '')
68             .length < prec) {
69         s[1] = s[1] || '';
70         s[1] += new Array(prec - s[1].length + 1)
71             .join('0');
72     }
73     return s.join(dec);
74 }

posted on 2017-07-21 15:53  济世魔王  阅读(297)  评论(0编辑  收藏  举报

导航