码迷,mamicode.com
首页 > 其他好文 > 详细

数值每三位加逗号

时间:2018-04-13 17:54:32      阅读:207      评论:0      收藏:0      [点我收藏+]

标签:unshift   split   ceil   数组   函数   and   str   ice   fun   

编写一个 toThousands 函数实现如下功能

toThousands(23456.89) // ‘23,456.89‘

方法一

循环使用 slice(-3)获取每组数字。

function toThousands(number) {
  var arr = String(number).split(‘.‘);
  var num = arr[0], result = ‘‘;
  while (num.length > 3) {
    result = ‘,‘ + num.slice(-3) + result;
    num = num.slice(0, num.length -3);
  }
  if (num.length > 0) result = num + result;
  return arr[1] ? result + ‘.‘ + arr[1] : result
}

方法二

在头部补全0,然后使用正则匹配,最后去除开头的零。padStart是ES6的方法,你也可以使用其他方法代替。

function toThousands(number) {
  var arr = String(number).split(‘.‘);
  var num = arr[0];
  var len = Math.ceil(num.length / 3) * 3;
  var result = num.padStart(len, ‘0‘).match(/\d{3}/g).join(‘,‘).replace(/^0+/, ‘‘);  
  return arr[1] ? result + ‘.‘ + arr[1] : result;
}

方法三

传化为数组进行操作,然后再拼接。

function toThousands(number) {
  var arr = String(number).split(‘.‘);
  var result = [], counter = 0;
  var num = arr[0].split(‘‘);
  for (var i = num.length - 1; i >= 0; i--) {
    counter++;
    result.unshift(num[i]);
    if (!(counter % 3) && i != 0) result.unshift(‘,‘);
  }
  return arr[1] ? result.join(‘‘) + ‘.‘ + arr[1] : result.join(‘‘);
}

方法四

使用 charAt 获取数字。

function toThousands(number) {
  var arr = String(number).split(‘.‘);
  var num = arr[0], result = ‘‘, counter = 0;
  for (var i = num.length - 1; i >= 0; i--) {
    counter++;
    result = num.charAt(i) + result;
    if (!(counter % 3) && i != 0) result = ‘,‘ + result;
  }
  return arr[1] ? result + ‘.‘ + arr[1] : result;
}

数值每三位加逗号

标签:unshift   split   ceil   数组   函数   and   str   ice   fun   

原文地址:https://www.cnblogs.com/liangxuru/p/8821572.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!