程序问答   发布时间:2022-06-01  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了D3 折线图中的多条线(汇总数据)大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

如何解决D3 折线图中的多条线(汇总数据)?

开发过程中遇到D3 折线图中的多条线(汇总数据)的问题如何解决?下面主要结合日常开发的经验,给出你关于D3 折线图中的多条线(汇总数据)的解决方法建议,希望对你解决D3 折线图中的多条线(汇总数据)有所启发或帮助;

我想在一个图表上放置多条线。我从使用 d3.nest().rollup() 聚合的标准 CSV 数据集开始。

使用我所知道的最佳方式,我对第一级键执行了 for 循环,然后绘制了第二级键和值。我的代码输出了正确的行数,但 Y 轴和 X 轴比例关闭。预期输出是一张包含 3 条线且均正确缩放的图。

编辑:一位同行让我知道该错误可能是由秤引起的。在控制台记录这些值后,它们似乎会导致问题。我将 xy.domain 移到 for 循环之外,它有助于缩放,但线条仍然无法正确显示。

请注意,在代码示例中,我预先格式化了数据:

<!DOCTYPE HTML>
<head>
  <Meta charset="utf-8">
  <script type="text/JavaScript" src="../lib/d3.v5.min.Js"></script>
  <script type="text/JavaScript" src="../lib/d3-dsv.min.Js"></script>
  <style>
    .line {
      fill: none;
      stroke-wIDth: 2px;
    }
  </style>
</head>

<body></body>

</script>
<script>
  var margin = {top: 100,right: 20,bottom: 50,left: 100},wIDth = 960 - margin.left - margin.right,height = 500 - margin.top - margin.bottom;

  var colorArray = [d3.scheR_421_11845@ecategory10][0]

  var x = d3.scalelinear().range([0,wIDth]);
  var y = d3.scalelinear().range([height,0]);

  var svg = d3.SELEct("body").append("svg")
      .attr("wIDth",wIDth + margin.left + margin.right)
      .attr("height",height + margin.top + margin.bottom + 50)
    .append("g")
      .attr("transform","translate(" + margin.left + "," + margin.top + ")");

  dataAgg = [
    {"key": 2015,"values": [
      {key: "3",value: 1},{key: "4",value: 19},{key: "5",value: 176},{key: "6",value: 524},{key: "7",value: 284},{key: "8",value: 31}]
    },{"key": 2016,value: 10},value: 88},value: 497},value: 410},value: 72},{key: "9",value: 3}]
    },{"key": 2017,"values": [
      {key: "6",value: 28},value: 78},value: 52},value: 8}]
    },]

  var valueline = d3.line()
    .x(function(d) { return x(d.key); })
    .y(function(d) { return y(d.value); });

  for (i = 0; i < dataAgg.length; i++) {
    yData = dataAgg[i].values
    yData.sort(function(a,b) { return +a.key  - +b.key })
    color = colorArraY[i]

    x.domain(d3.extent(yData,function(d) { return d.key; }));
    y.domain([0,d3.max(yData,function(d) { return d.value; })]);

    svg.append("path")
        .data([yData])
        .attr("class","line")
        .attr("d",valuelinE)
        .attr('stroke',color)
  }

  svg.append("g")
      .attr("transform","translate(0," + height + ")")
      .call(d3.axisBottom(X));

  svg.append("g")
      .call(d3.axisleft(y));
</script>

解决方法

通过将 xy.domain 行移出 for 循环并稍微编辑它们以使其更具动态性,我能够解决该问题:

  x.domain(d3.extent(dataAgg.map(d => d.values).flat(),v => v.key));
  y.domain([0,d3.max(dataAgg.map(d => d.values).flat(),v => v.value)]);

大佬总结

以上是大佬教程为你收集整理的D3 折线图中的多条线(汇总数据)全部内容,希望文章能够帮你解决D3 折线图中的多条线(汇总数据)所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签: