以下是我的d3js图表http://enjalot.com/inlet/4159384/的链接 问题是显示Year的y轴对于json数据具有诸如2008.5和2009.0的值
[{count:200,year:2008},
{count:240,year:2010},
{count:290,year:2009}];
我想显示没有任何小数点的年份。如何做到这一点。 这是我在下面的d3js代码
var w = 300,
h = 300,
padding = 31,
p = 10;
var data = [{count:200,year:2008},
{count:240,year:2010},
{count:290,year:2009}];
var bar_height = d3.scale.linear()
.domain(d3.extent(data, function(d) { return d.count; }) ) // min max of count
.range([p,h-p]); // min max of area to plot in
var bar_xpos = d3.scale.linear()
.domain(d3.extent(data, function(d) { return d.year; }) ) // min max of year
.range([p,w-p]); // min max of area to plot in
var xAxis = d3.svg.axis()
.scale(bar_xpos)
.orient("bottom")
.ticks(5); //Set rough # of ticks
var yAxis = d3.svg.axis()
.scale(bar_height)
.orient("left")
.ticks(5);
var svg = d3.select("svg")
.attr("width", w)
.attr("height", h);
svg.append("g")
.attr("class", "axis")
.attr("transform", "translate(0," + (h - padding) + ")")
.call(xAxis);
svg.append("g")
.attr("class", "axis")
.attr("transform", "translate(" + padding + ",0)")
.call(yAxis);
答案 0 :(得分:17)
查看d3 value formatting上的文档。
如果使用d3.format()
格式化轴,则轴值看起来会更好。
var formatxAxis = d3.format('.0f');
var xAxis = d3.svg.axis()
.scale(bar_xpos)
.orient("bottom")
.tickFormat(formatxAxis)
.ticks(5);
.0f
表示:
我想要小数点后的 0 位置的精度,我希望值固定,即不是舍入而是截断。
但是,您会注意到,由于您将精度修正为小数点后的0位,因此将2009.5和2009.0格式化为2009.这意味着两个轴刻度可以具有相同的值。一旦你有足够的数据点多年,这个错误就会消失。