作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我希望 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/
出于好奇,我尝试了一些原型(prototype)制作,但似乎只允许在第一个位置使用子例程的原型(prototype) &。 当我写作时 sub test (&$$) { do_somethin
我需要开发一个类似于 Android Play 商店应用程序或类似 this app 的应用程序.我阅读了很多教程,发现几乎每个教程都有与 this one 类似的例子。 . 我已经开始使用我的应用程
考虑一个表示“事件之间的时间”的列: (5, 40, 3, 6, 0, 9, 0, 4, 5, 18, 2, 4, 3, 2) 我想将这些分组到 30 个桶中,但桶会重置。期望的结果: (0, 1,
我是一名优秀的程序员,十分优秀!