如何从d3js图中的y轴刻度中删除小数点

iJa*_*ade 4 javascript charts svg canvas d3.js

这里是我的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}];
Run Code Online (Sandbox Code Playgroud)

我想显示没有任何小数点的年份.如何做到这一点.这是我下面的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);
Run Code Online (Sandbox Code Playgroud)

小智 18

查看有关d3值格式的文档.

如果您使用d3.format()格式化轴,则轴值看起来会更好.

var formatxAxis = d3.format('.0f');

var xAxis = d3.svg.axis()
            .scale(bar_xpos)
            .orient("bottom")
            .tickFormat(formatxAxis)
            .ticks(5); 
Run Code Online (Sandbox Code Playgroud)

.0f意思是:
我想要小数点后0位的精度,我想要修复值,即不是舍入而是截断.

但是,您会注意到,由于您将精度修正为小数点后的0位,因此将2009.5和2009.0格式化为2009.这将意味着两个轴刻度可以具有相同的值.一旦你有足够的数据点多年,这个错误就会消失.