在d3 js中仅在x轴上表示年份的比例

时间:2015-09-06 20:44:21

标签: javascript d3.js

我一直在D3 J中开发年份(x轴)与收入(y轴)的面积图。数据如下:

localData=[
        {"Revenue":"4.5","Year":"2011"},
        {"Revenue":"5.5","Year":"2010"},
        {"Revenue":"7.0","Year":"2012"},
        {"Revenue":"6.5","Year":"2013"}
       ]

我希望x轴上的年份和面积图的y轴收入。目前我正在使用x轴的时间刻度,但我不知道如何使用它,因为我没有日期格式我只有几年代表。< / p>

我的当前代码是:

 var margin = { top: 20, right: 20, bottom: 30, left: 50 },
                width = 500 - margin.left - margin.right,
                height = 300 - margin.top - margin.bottom;
            var parseDate = d3.time.format("%Y").parse;

            var x = d3.time.scale()
                      .range([0, width]);


            var y = d3.scale.linear()
                .range([height, 0]);
            var xAxis = d3.svg.axis()
                            .scale(x)
                            .orient("bottom");

            var yAxis = d3.svg.axis()
                .scale(y)
                .orient("left");


            var area = d3.svg.area()
                .x(function (d) { return x(d.Year); })
                .y0(height)
                .y1(function (d) { return y(d.Revenue); });
            $("#chartArea").html("");
            var svg = d3.select("#chartArea").append("svg")
                        .attr("width", width + margin.left + margin.right)
                        .attr("height", height + margin.top + margin.bottom)
                      .append("g")
                        .attr("transform", "translate(" + margin.left + "," + margin.top + ")");
            x.domain(d3.extent(localData, function (d) { return d.Year; }));
            y.domain([0, d3.max(localData, function (d) { return d.Revenue; })]);
            svg.append("path")
                 .datum(localData)
                 .attr("class", "area")
                 .attr("d", area)
                .attr("fill",color);
            svg.append("g")
                      .attr("class", "x axis")
                      .attr("transform", "translate(0," + height + ")")
                      .call(xAxis);

            svg.append("g")
                .attr("class", "y axis")
                .call(yAxis)
            .append("text")
              .attr("transform", "rotate(-90)")
              .attr("y", 6)
              .attr("dy", ".71em")
              .style("text-anchor", "end")
              .text("Revenue (M)");

目前我的X轴已经是.011,.012,013,.014我需要2011,2012,2013,2014 我是D3 js的新手,所以dnt知道如何使用秤?请帮助任何人......提前谢谢。

3 个答案:

答案 0 :(得分:4)

只需在您的x轴定义中添加tick格式:

  var xAxis = d3.svg.axis()
              .scale(x)
              .orient("bottom")
              .tickFormat(d3.time.format("%Y")); // <-- format

答案 1 :(得分:2)

在第4节中,它是这样的:

d3.axisBottom(x).ticks(d3.timeYear.every(1))

答案 2 :(得分:1)

欢锋是对的。时间刻度将您的年份(隐式转换为int)视为时间戳。要强制比例在年份上运行,请创建指定日期的Date对象。基本上更改以下行:

x.domain(d3.extent(localData, function (d) { return d.Year; }));

x.domain(d3.extent(localData, function (d) { return new Date(parseInt(d.Year),0); }));

然后您可以使用克劳耶西的解决方案来更改tickFormat。