javascript - D3 强制定向 JSON 邻接表

标签 javascript php json d3.js force-layout

我有一个图邻接列表,如下所示:

{
  nodes: [
  {
    "id": 1,
    "label": "Mark
  },...],

  edges: [
  {
    "source": 1,
    "target": 2
  },....]
}

边使用节点的 id!

我一直在使用 PHP 将此列表回显到客户端。

D3 无法从文件加载我的 JSON。 所以我尝试手动解析它:

var width = window.innerWidth,
      height = window.innerHeight;

  var color = d3.scale.category20();

  var force = d3.layout.force()
      .linkDistance(40)
      .linkStrength(2)
      .charge(-120)
      .size([width, height]);

  var svg = d3.select("body").append("svg")
      .attr("width", width)
      .attr("height", height);

  var nodes = [], links = [];

  d3.json( null, function( error )
  {
    JSONData.nodes.forEach( function(node)
    {
      nodes.push( node );
    });

    JSONData.edges.forEach( function(edge)
    {
      links.push({source: edge.source, target: edge.target});
    });

    force.nodes(nodes)
     .links(links)
     .start();

    var link = svg.selectAll(".link")
          .data(links)
          .enter().append("path")
          .attr("fill", "none")
          .attr("class", "link");

    var node = svg.selectAll(".node")
          .data(nodes)
          .enter().append("circle")
          .attr("class", "node")
          .attr("r", 5)
          .style("fill", "#4682B4" )
          .call(force.drag);

    node.append("title").text(function(d) { return d.label; });

    force.on("tick", function() 
    {
      link.attr("x1", function(d) { return d.source.x; })
      .attr("y1", function(d) { return d.source.y; })
      .attr("x2", function(d) { return d.target.x; })
      .attr("y2", function(d) { return d.target.y; });

      node.attr("cx", function(d) { return d.x; })
      .attr("cy", function(d) { return d.y; });
    });
  });

但是,我只能看到节点,而看不到边缘。 我添加了一个 CSS 文件:

.node {
  stroke: #4682B4;
  stroke-width: 1.5px;
}

.link {
  stroke: #ddd;
  stroke-width: 1.5px;
}

但是没有效果。 有什么办法可以解决这个问题吗?

最佳答案

您需要使用:

      .enter().append("line")

而不是

      .enter().append("path")

(也许您还需要更改一些其他属性,以便它们对应于线,而不是路径)。

或者,您可以绘制一些更复杂的路径而不是直线,但我认为这对您的情况来说是一种矫枉过正。

编辑:

我刚刚发现两个相关且有趣的问题:

enter link description here - 描述了在力布局中显示链接时的另一种问题 - 确保您不会遇到类似的障碍

enter link description here - 如果你决定做类似的事情,一个人试图画曲线而不是直线

但希望这个答案和评论中的提示足以让你得到你想要的。

关于javascript - D3 强制定向 JSON 邻接表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21771095/

相关文章:

php - RabbitMQ 实现

django - 无法使用带有 Django 的 MongoEngine Pymongo 返回 JSON 对象?

html - 如何在html中显示Json数据到对话框

javascript - 用于自动完成搜索的 MongoDB + Node.js + AJAX 解决方案

php - MYSQL/PHP-从数据库中回显插入的数据

javascript - 使用变量从数组中获取数据

php - 自定义 phpcs 规则集不遵守排除模式声明

Javascript 在此 JSON 中添加一个变量

javascript - 使用 "Break on Next"调试时如何排除 setTimeout 或 setInterval 类型的语句?

javascript - 使用 Fabric.js 进行交互式绘图