最近做項(xiàng)目需要我們前端對(duì)金額進(jìn)行千分位格式化(也就是說每三位用逗號(hào)隔開),代碼已經(jīng)做了修改 之前的版本是本人疏忽 真對(duì)不住大家了!現(xiàn)在已經(jīng)做了修改 如果還有不完善的地方 請(qǐng)大家多多指教!
1. 支持用逗號(hào)隔開 0-9位 逗號(hào)隔開
JS代碼如下:
if(isNumber(number) || isString(number) || REG_NUMBER.test(number)) {
// 先轉(zhuǎn)換成字符串
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 "有錯(cuò)誤";
}
}else {
return '傳入的要格式化的數(shù)字不符合';
}
}
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'];
}
但是貌似還有一個(gè)不完善的地方 就是 我這樣調(diào)用 console.log(numFormat("1111.00")); 在控制臺(tái)上 直接輸出 1,111 而不是1,111.00 也就是說 如果小數(shù)點(diǎn)后面的是 0的話 游覽器自動(dòng)會(huì)抹掉后面的0 其他的都正常!本人測(cè)試了下 基本符合要求 如有不完善的地方 請(qǐng)大家多多指教!
新聞熱點(diǎn)
疑難解答
圖片精選
網(wǎng)友關(guān)注