矩形不会出现在d3直方图上

时间:2017-02-17 17:45:16

标签: javascript d3.js svg polymer

我正在使用Polymer来渲染一些d3图表。最初渲染Polymer时,我只绘制一个带有轴而没有数据的图形,因为一旦API调用成功,数据就会出现。但是,当我开始在svg中添加'rect'元素时,尽管它们出现在Chrome devtools元素检查器中,但它们并没有显示在图表本身中。

dataChanged: function() {
    var data = this.data;
    var margin = {top: 20, right: 20, bottom: 30, left: 50},
        width = this.width - margin.left - margin.right,
        height = this.height - margin.top - margin.bottom;

      // format the data
    data.forEach(function(d) {
        d.date = d3.isoParse(d.date);
    });

    // set the ranges
    var x = d3.scaleTime()
        .domain(d3.extent(data, function(d) { return d.date; }))
        .rangeRound([0, width]);
    var y = d3.scaleLinear()
        .range([height, 0]);

    var svg = d3.select(this.$.chart);

    var histogram = d3.histogram()
        .value(function(d) { return d.date; })
        .domain(x.domain())
        .thresholds(x.ticks(d3.timeMonth));

    var bins = histogram(data);

    y.domain([0, d3.max(bins, function(d) { return d.length; })]);


    var t = d3.transition()
        .duration(750)
        .ease(d3.easeLinear);

    svg.selectAll("rect")
        .data(bins)
        .enter().append("rect")
        .attr("class", "bar")
        .attr("x", 1)
        .attr("transform", function(d) {
          return "translate(" + x(d.x0) + "," + y(d.length) + ")";
        })
        .attr("width", function(d) { return x(d.x1) - x(d.x0) -1 ; })
        .attr("height", function(d) { return height - y(d.length); });

    svg.select(".xAxis")
        .transition(t)
        .call(d3.axisBottom(x));

    svg.select(".yAxis")
        .transition(t)
        .call(d3.axisLeft(y));
},
ready: function() {
    var margin = {top: 20, right: 20, bottom: 30, left: 50},
        width = this.width - margin.left - margin.right,
        height = this.height - margin.top - margin.bottom;

    // set the ranges
    var x = d3.scaleTime()
        .domain([new Date(2010, 6, 3), new Date(2012, 0, 1)])
        .rangeRound([0, width]);
    var y = d3.scaleLinear()
        .range([height, 0]);

    // Add the SVG to my 'chart' div.    
    var svg = d3.select(this.$.chart).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 + ")");

    // Add the X Axis
    svg.append("g")
        .attr("class","xAxis")
        .attr("transform", "translate(0," + height + ")")
        .call(d3.axisBottom(x));

    // Add the Y Axis
    svg.append("g")
        .attr("class","yAxis")
        .call(d3.axisLeft(y));
 }
当父组件传递一大块数据时,

ready()在渲染时被调用{/ 1}}。

正确地渲染轴,使用正确的过渡和正确的尺寸,但是没有。它们显示在chrome元素检查器中,大小为0x17,即使它们看起来像这样:dataChanged()

1 个答案:

答案 0 :(得分:0)

ready函数中,您抓住div创建svg元素,添加g元素,然后将轴追加到g

dataChanged功能中,您抓住div并将rects附加到其中。

看到断开连接?您不能将svg作为HTML格式。

ready执行此操作:

 var svg = d3.select(this.$.chart).append("svg")
   .attr("width", width + margin.left + margin.right)
   .attr("height", height + margin.top + margin.bottom)
   .append("g")
   .attr("id", "canvas")
   .attr("transform",
         "translate(" + margin.left + "," + margin.top + ")");

dataChanged

var svg = d3.select("#canvas");

这将允许您“找到”相应的g以附加您的作品。