【问题标题】:Parsing and invalid value for D3.js sankeyD3.js sankey 的解析和无效值
【发布时间】:2014-01-12 21:04:40
【问题描述】:

我目前正在尝试使用 D3.js 创建一个简单的桑基图。我已经完成了大部分工作,但设置高度和 y 轴被证明是一个挑战。具体返回的错误如下:

错误:解析问题 d="M15, NaNC479, NaN 479, NaN 943, NaN" 错误: 属性 height = "NaN" 的值无效

我已尝试按照示例进行操作(有效):http://bost.ocks.org/mike/sankey/ 我的例子在这里:http://zenbot.ca/elections.html

请注意,下面的文本(“Brockville”、“Central Toronto”等)只是一个测试,以确保我正确连接到 JSON 文件,因此您可以忽略它。页面顶部的 blob 应该看起来像 Sankey 图,但目前不是。

我的 JSON 样本(可在 http://zenbot.ca/js/electionJSON.json 获得)似乎以与 Bostock 先生的示例 (http://bost.ocks.org/mike/sankey/energy.json) 相同的方式形成,如下所示:

{
  "nodes": [
    {"name": "Brockville"},
    {"name": "Central Toronto"},
    ...
  ],
  "links": [
    {"source": 0, "type": "Individual", "target": 26, "amount": 500},
    {"source": 5, "type": "Individual", "target": 16, "amount": 200},
    ...
  ]
}

我自己尝试解决问题的方法是使用“d.dy”值(尝试用“d.amount”替换它)。将其硬编码为“100”而不是大约第 79 行的函数会使一个节点出现,但其余的仍然是一团乱麻。

所以...这似乎取决于节点的高度和位置。它看起来很像 Bostock 的例子,但显然不是。有什么想法吗?

使sankey工作的代码如下:

d3.json("js/electionJSON.json", function(election) {

  sankey
      .nodes(election.nodes)
      .links(election.links)
      .layout(32);

  var link = svg.append("g").selectAll(".link")
      .data(election.links)
    .enter().append("path")
      .attr("class", "link")
      .attr("d", path)
      .style("stroke-width", function(d) { return Math.max(1, d.dy); })
      .sort(function(a, b) { return b.dy - a.dy; });

  link.append("title")
      .text(function(d) { return d.source.name + " → " + d.target.name + "\n" + format(d.amount); });

  var node = svg.append("g").selectAll(".node")
      .data(election.nodes)
    .enter().append("g")
      .attr("class", "node")
      .attr("transform", function(d) { return "translate(" + d.x + "," + d.y + ")"; })
    .call(d3.behavior.drag()
      .origin(function(d) { return d; })
      .on("dragstart", function() { this.parentNode.appendChild(this); })
      .on("drag", dragmove));

  node.append("rect")
      .attr("height", function(d) { return d.dy; })
      .attr("width", sankey.nodeWidth())
      .style("fill", function(d) { return d.color = color(d.name.replace(/ .*/, "")); })
      .style("stroke", function(d) { return d3.rgb(d.color).darker(2); })
    .append("title")
      .text(function(d) { return d.name + "\n" + format(d.amount); });

  node.append("text")
      .attr("x", -6)
      .attr("y", function(d) { return d.dy / 2; })
      .attr("dy", ".35em")
      .attr("text-anchor", "end")
      .attr("transform", null)
      .text(function(d) { return d.name; })
    .filter(function(d) { return d.x < width / 2; })
      .attr("x", 6 + sankey.nodeWidth())
      .attr("text-anchor", "start");

  function dragmove(d) {
    d3.select(this).attr("transform", "translate(" + d.x + "," + (d.y = Math.max(0, Math.min(height - d.dy, d3.event.y))) + ")");
    sankey.relayout();
    link.attr("d", path);
  }
});

【问题讨论】:

    标签: javascript json d3.js sankey-diagram


    【解决方案1】:

    您可能会为此而自责,但对我来说玩 sankey 实现很有趣。您现在最大的问题是electionJSON.json 中的数据使用amount 作为值。然而 sankey 期望该值被称为value

    function value (link) {
      return link.value;
    }
    

    这将始终在您的数据集中返回 undefined。似乎 sankey 在多个地方都做了这个假设,所以我最终使用 sed 将“金额”一词替换为“价值”。这似乎起到了作用。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2013-09-05
      • 1970-01-01
      • 1970-01-01
      • 2019-08-03
      • 2016-06-30
      • 2015-07-04
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多