如何使用SI前缀格式四舍五入到小数点后2位?

我的案例中的示例:

d3.format("~s")(656628); //656.628k

但我的预期结果:656.63k

我希望使用d3格式选项,而不是手动处理。

实时测试:https://npm.runkit.com/d3-format


解决方案

您只需要d3.formatPrefix,它...

在以定点表示法格式化之前,将值转换为指定数字参考值的相应SI前缀的单位。

...,".2"作为说明符,您自己的数字作为值。

这是带有您的号码的演示:

数据-lang="js"数据-隐藏="假"数据-控制台="真"数据-巴贝尔="假">
const myNumber = 656628;
console.log(d3.formatPrefix(".2", myNumber)(myNumber));
<script src="https://cdnjs.cloudflare.com/ajax/libs/d3/5.7.0/d3.min.js"></script>

这将为您提供预期结果:656.63k

为了完整起见,还提供了其他一些数字:

数据-lang="js"数据-隐藏="假"数据-控制台="真"数据-巴贝尔="假">
[1232, 7676546655, 665, 0.0012, 8887878].forEach(function(d) {
  console.log("Number: " + d + " - Your format: " + d3.formatPrefix(".2", d)(d))
});
<script src="https://cdnjs.cloudflare.com/ajax/libs/d3/5.7.0/d3.min.js"></script>

相关文章