d3.format变量的千位分隔符?

5

你好,我又被d3困住了...

我想知道如何在变量上使用千位分隔符,我找到的所有示例似乎都是针对静态数据的。

这是我目前尝试过的:

d3.csv("OrderValueToday.csv", function(obj) { 

var text = 'Today = £';
var totalSales = text + d3.format(",") + obj[0].Today;

svgLabel = d3.select("#label").append("h2")
 .text (totalSales);

});

然而,它只是在网页上输出了一堆东西,如下所示:
Today = £function (n){var e=d;if(m&&n%1)return"";var u=0>n||0===n&&0>1/n?(n=-n,"-"):a;    if(0>p){var c=Zo.formatPrefix(n,h);n=c.scale(n),e=c.symbol+d}else n*=p;n=g(n,h);var x=n.lastIndexOf("."),M=0>x?n:n.substring(0,x),_=0>x?"":t+n.substring(x+1);!s&&f&&(M=i(M));var b=v.length+M.length+_.length+(y?0:u.length),w=l>b?new Array(b=l-b+1).join(r):"";return y&&(M=i(w+M)),u+=v,n=M+_,("<"===o?u+n+w:">"===o?w+u+n:"^"===o?w.substring(0,b>>=1)+u+n+w.substring(b):u+(y?n:w+n))+e}20000

所需的只是使totalSales值具有千位分隔符,如20,000,但我尝试过的所有方法都无效。我阅读了https://github.com/mbostock/d3/wiki/Formatting,但没有找到适用于我的情况的解决方案。如能提供帮助将不胜感激。谢谢。
1个回答

6

指定d3.format会返回一个格式化函数,您需要将其作为函数调用,并将要进行格式化的数字作为参数传递:

var myNumber = 22400;
d3.format(',')(myNumber); // returns '22,400'

有时你会看到一个被存储为变量的格式化函数,就像这样:
var commaFormat = d3.format(',');
commaFormat(1234567); // returns '1,234,567'

在您的情况下,您可以执行以下操作:
var totalSales = text + d3.format(',')(obj[0].Today);

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接