js格式化数字和金额
格式化数字,格式化金额:
1 function number_format(number, decimals, dec_point, thousands_sep) { 2 /* 3 * 参数说明: 4 * number:要格式化的数字 5 * decimals:保留几位小数 6 * dec_point:小数点符号 7 * thousands_sep:千分位符号 8 * */ 9 number = (number + '').replace(/[^0-9+-Ee.]/g, ''); 10 var n = !isFinite(+number) ? 0 : +number, 11 prec = !isFinite(+decimals) ? 0 : Math.abs(decimals), 12 sep = (typeof thousands_sep === 'undefined') ? ',' : thousands_sep, 13 dec = (typeof dec_point === 'undefined') ? '.' : dec_point, 14 s = '', 15 toFixedFix = function (n, prec) { 16 var k = Math.pow(10, prec); 17 return '' + Math.ceil(n * k) / k; 18 }; 19 20 s = (prec ? toFixedFix(n, prec) : '' + Math.round(n)).split('.'); 21 var re = /(-?\d+)(\d{3})/; 22 while (re.test(s[0])) { 23 s[0] = s[0].replace(re, "$1" + sep + "$2"); 24 } 25 26 if ((s[1] || '').length < prec) { 27 s[1] = s[1] || ''; 28 s[1] += new Array(prec - s[1].length + 1).join('0'); 29 } 30 return s.join(dec); 31 }
如何使用:
1 var num=number_format(1234567.089, 2, ".", ",");//1,234,567.09
再来一个,直接舍去的办法:
1 function number_format(number, decimals, dec_point, thousands_sep) { 2 /* 3 * 参数说明: 4 * number:要格式化的数字 5 * decimals:保留几位小数 6 * dec_point:小数点符号 7 * thousands_sep:千分位符号 8 * */ 9 number = (number + '').replace(/[^0-9+-Ee.]/g, ''); 10 var n = !isFinite(+number) ? 0 : +number, 11 12 prec = !isFinite(+decimals) ? 0 : Math.abs(decimals), 13 sep = (typeof thousands_sep === 'undefined') ? ',' : thousands_sep, 14 dec = (typeof dec_point === 'undefined') ? '.' : dec_point, 15 s = '', 16 toFixedFix = function (n, prec) { 17 var k = Math.pow(10, prec); 18 return '' + Math.floor(n * k) / k; 19 }; 20 s = (prec ? toFixedFix(n, prec) : '' + Math.floor(n)).split('.'); 21 var re = /(-?\d+)(\d{3})/; 22 console.log(s) 23 while (re.test(s[0])) { 24 s[0] = s[0].replace(re, "$1" + sep + "$2"); 25 } 26 27 if ((s[1] || '').length < prec) { 28 s[1] = s[1] || ''; 29 s[1] += new Array(prec - s[1].length + 1).join('0'); 30 } 31 return s.join(dec); 32 } 33 number_format(1234567.089, 2, ".", ",");//1,234,567.08
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· Obsidian + DeepSeek:免费 AI 助力你的知识管理,让你的笔记飞起来!
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了