javascript - 仅当数字有小数位时才将数字格式化为 2 位小数

标签 javascript d3.js

我希望 d3 将我的数字格式化为 2 个小数位,前提是它具有十进制值。 另外,我希望它使用一种格式函数。

目前,我一直在使用它。有什么方法可以改进这个问题以解决这个问题吗?

d3.format(",.2f")(10101); //10,101.00 which must be displayed as 10,000 only

d3.format(",.2f")(12334.2); //12,334.20 this is okay

最佳答案

I want it to work with one single format function

嗯,那是不可能的。 D3 格式函数无法适应您像那样传递给它们的数字。

但是,您可以有两个 格式函数,并测试您传递的数字是否有小数位。这是一种可能的测试方法:

number % 1

对于整数返回 0。

然后,在 ternary operator 中,您可以选择要使用的 d3.format 函数:

!(number % 1) ? someFormat(number) : otherFormat(number)

这是一个演示:

var formatInteger = d3.format(",");
var formatDecimal = d3.format(",.2f");

var number1 = 10101;
var number2 = 12334.2;

function format(number){
return !(number % 1) ? formatInteger(number) : formatDecimal(number)
}

console.log(format(number1))
console.log(format(number2))
<script src="https://d3js.org/d3.v4.min.js"></script>

关于javascript - 仅当数字有小数位时才将数字格式化为 2 位小数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41910436/

相关文章:

javascript - 减少 D3 散点图矩阵中的绘图数量

javascript - 计算距离并从谷歌地图中的原点移动标记

javascript - jQuery-ajax 'on click event' 不工作

javascript - d3 js - 如何反转 d3.extent

d3.js - 使用 dc 或 d3.js 中具有正负 y 轴的面积图制作图表

javascript - d3.js 日期时间格式说明符未按预期工作

javascript - Angular 应用程序中的浏览器功能检测 : use service, 指令, Controller ?

javascript - 为什么需要 8 个反斜杠?

javascript - 检查传递给我们监视的函数的参数的属性

javascript - R中的htmlwidgets中没有图形输出