在 JavaScript 中,如何编写一个函数,将给定的 [edit: positive integer ] 数字(低于 1000 亿)转换为 3 个字母的缩写——其中 0-9 和 az/AZ 算作一个字母,但点(因为它在许多比例字体中是如此之小)不会,并且会在字母限制方面被忽略?
这个问题与这个有用的线程有关,但不一样;例如,该函数将变为例如“123456 -> 1.23k”(“123.5k”是5个字母)我正在寻找可以执行“123456 -> 0.1m”的东西(“0[.]1m”是3个字母)。例如,这将是希望函数的输出(左原始,右理想返回值):
0 "0"
12 "12"
123 "123"
1234 "1.2k"
12345 "12k"
123456 "0.1m"
1234567 "1.2m"
12345678 "12m"
123456789 "0.1b"
1234567899 "1.2b"
12345678999 "12b"
谢谢!
更新:谢谢!当进行以下修改时,答案就在其中并按照要求工作:
function abbreviateNumber(value) {
var newValue = value;
if (value >= 1000) {
var suffixes = ["", "k", "m", "b","t"];
var suffixNum = Math.floor( (""+value).length/3 );
var shortValue = '';
for (var precision = 2; precision >= 1; precision--) {
shortValue = parseFloat( (suffixNum != 0 ? (value / Math.pow(1000,suffixNum) ) : value).toPrecision(precision));
var dotLessShortValue = (shortValue + '').replace(/[^a-zA-Z 0-9]+/g,'');
if (dotLessShortValue.length <= 2) { break; }
}
if (shortValue % 1 != 0) shortValue = shortValue.toFixed(1);
newValue = shortValue+suffixes[suffixNum];
}
return newValue;
}