千分位数字格式化(用逗号隔开 代码已做了修改 支持0-9位逗号隔开)的JS代码
时间:2023-08-19 20:33:57
最近做项目需要我们前端对金额进行千分位格式化(也就是说每三位用逗号隔开),代码已经做了修改 之前的版本是本人疏忽 真对不住大家了!现在已经做了修改 如果还有不完善的地方 请大家多多指教!
1. 支持用逗号隔开 0-9位 逗号隔开
JS代码如下:
/**
* JS格式化
* @param number 要格式化的数字
* @param d [0-9]位 逗号隔开
*/
function numFormat(number,d) {
var numArrs = ['0','1','2','3','4','5','6','7','8','9'],
REG_NUMBER = /^\d+(.\d+)?$/;
d = d || 3; // 不传 是3位 千分位
if(isNumber(number) || isString(number) || REG_NUMBER.test(number)) {
// 先转换成字符串
var toString = number + '',
isPoint = toString.indexOf('.'),
prefix, // 前缀
suffix, // 后缀
t = '';
if(isPoint > 0) {
prefix = toString.substring(0,isPoint);
suffix = toString.substring(isPoint + 1);
}else if(isPoint == 0) {
prefix = '';
suffix = toString.substring(1);
}else {
prefix = toString;
suffix = '';
}
if(prefix != '') {
prefixArr = prefix.split('').reverse();
var isArrayIndex = isArray(d,numArrs);
if(isArrayIndex > -1) {
for(var i = 0, ilen = prefixArr.length; i < ilen; i+=1) {
t += prefixArr[i] + ((i + 1) % isArrayIndex == 0 && (i + 1) != prefixArr.length ? "," : "");
}
t = t.split("").reverse().join("");
if(suffix != '') {
return t + "." + suffix;
}else {
return t;
}
}else {
return '传入的多少位不正确';
}
}else if(prefix != '' && suffix == ''){
return prefix;
}else if(prefix == '' && suffix != ''){
prefix = 0;
return prefix + suffix;
}else {
return "有错误";
}
}else {
return '传入的要格式化的数字不符合';
}
}
function isArray(item,arrs) {
for(var i = 0, ilen = arrs.length; i < ilen; i++) {
if(item == arrs[i]) {
return i;
}
}
return -1;
}
function isNumber(number) {
return Object.prototype.toString.apply(number) === '[object Number]';
}
function isString(number) {
return Object.prototype.toString.apply(number) === ['object String'];
}
但是貌似还有一个不完善的地方 就是 我这样调用 console.log(numFormat("1111.00")); 在控制台上 直接输出 1,111 而不是1,111.00 也就是说 如果小数点后面的是 0的话 游览器自动会抹掉后面的0 其他的都正常!本人测试了下 基本符合要求 如有不完善的地方 请大家多多指教!
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
tensorflow实现对图片的读取的示例代码
![](https://img.aspxhome.com/file/2023/7/63517_0s.jpg)
Python实现扣除个人税后的工资计算器示例
![](https://img.aspxhome.com/file/2023/8/81678_0s.png)
让Entity Framework支持MySql数据库
![](https://img.aspxhome.com/file/UploadPic/201012/14/20101214153519606s.png)
vue语法之拼接字符串的示例代码
![](https://img.aspxhome.com/file/2023/0/130260_0s.png)
Java操作Mysql的方法
基于Python实现自制拼图小游戏
![](https://img.aspxhome.com/file/2023/9/92099_0s.gif)
探讨SQL利用INFORMATION_SCHEMA系统视图如何获取表的主外键信息
![](https://img.aspxhome.com/file/2023/0/121240_0s.jpg)
python3.8下载及安装步骤详解
![](https://img.aspxhome.com/file/2023/5/123835_0s.png)
Golang分布式应用定时任务示例详解
![](https://img.aspxhome.com/file/2023/1/107361_0s.jpg)
JS获取页面窗口实际大小函数
使用Python实现大学座位预约功能
![](https://img.aspxhome.com/file/2023/4/127594_0s.png)
浅谈javascript:两种注释,声明变量,定义函数
![](https://img.aspxhome.com/file/2023/4/136674_0s.jpg)
Python List remove()实例用法详解
Python基础知识之函数,类,模块
![](https://img.aspxhome.com/file/2023/1/95701_0s.png)
python中使用docx模块处理word文档
![](https://img.aspxhome.com/file/2023/3/90703_0s.png)
fckeditor 常用函数
python executemany的使用及注意事项
Python开发之快速搭建自动回复微信公众号功能
![](https://img.aspxhome.com/file/2023/8/117288_0s.jpg)
Python 统计位数为偶数的数字代码详解
python numpy存取文件的方式
![](https://img.aspxhome.com/file/2023/2/96932_0s.png)