D3强制布局:链接和节点--- z-index(?)

use*_*872 6 z-index d3.js force-layout

D3:节点和链接之间的问题

我创建了以下jsfiddle以了解我正在尝试实现的目标:

在此输入图像描述

我希望节点结束(?)链接...

请帮我.对不起我的英文:)

脚本看起来像这样:

function myGraph(el) {
this.addNode = function (id) {
    nodes.push({ "id": id });
    update();
}
this.removeNode = function (id) {
    var i = 0;
    var n = findNode(id);
    while (i < links.length) {
        if ((links[i]['source'] == n) || (links[i]['target'] == n)) links.splice(i, 1);
        else i++;
    }
    nodes.splice(findNodeIndex(id), 1);
    update();
}
this.addLink = function (source, target) {
    links.push({ "source": findNode(source), "target": findNode(target) });
    update();
}
var findNode = function (id) {
    for (var i in nodes) { if (nodes[i]["id"] === id) return nodes[i] };
}
var findNodeIndex = function (id) {
    for (var i in nodes) { if (nodes[i]["id"] === id) return i };
}
// set up the D3 svg in the specified element
var w = window.jQuery(el).innerWidth(),
    h = window.jQuery(el).innerHeight();
var svg = this.svg = d3.select(el).append("svg:svg")
    .attr("width", w)
    .attr("height", h);
var force = d3.layout.force()
    .gravity(.05)
    .distance(100)
    .charge(-120)
    .size([w, h]);
var nodes = force.nodes(),
    links = force.links();
var update = function () {
    var link = svg.selectAll(".link")
        .data(links, function (d) { return d.source.id + "-" + d.target.id; })
    link.enter().append("line")
        .attr("class", "link")
    link.exit().remove();
    var node = svg.selectAll(".node")
        .data(nodes, function (d) { return d.id; })
    node.enter().append("g")
        .attr("class", "node")
        .call(force.drag);
    node.append("circle")
        .attr("r", function (d) { return 30; })
        .style("fill", "#EFEFEF")
    node.append("text")
        .attr("text-anchor", "right")
        .text(function (d) { return d.id; });
    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("transform", function (d) { return "translate(" + d.x + "," + d.y + ")"; });
    });
    // Restart the force layout.
    force.start();
}
// Make it all go
update();
}
graph = new myGraph("#graph");
// You can do this from the console as much as you like...
graph.addNode("Cause");
graph.addNode("Effect");
graph.addLink("Cause", "Effect");
graph.addNode("A");
graph.addNode("B");
graph.addLink("A", "B");
Run Code Online (Sandbox Code Playgroud)

Lar*_*off 11

z-indexSVG 没有房产; 元素按照指定的顺序呈现.这意味着所有链接元素都需要在生成的DOM中的节点元素之前.

实现这一目标的最简单方法是g为链接和节点分别设置元素,前者首先使用前者.

svg.append("g").attr("class", "links");
svg.append("g").attr("class", "nodes");
Run Code Online (Sandbox Code Playgroud)

然后你可以附加这样的链接

var link = svg.select(".links").selectAll(".link")
         .data(links, function (d) { return d.source.id + "-" + d.target.id; })
// etc
Run Code Online (Sandbox Code Playgroud)

和节点同样.在这里完成演示.

  • 虽然这种技术对我有用,但问题是当我必须添加/删除新节点/链接时.例如,添加新链接时,链接将显示在它所连接的两个节点的顶​​部.有没有办法让它总是出现在节点下面?我尝试添加一个额外的空`g`,但是我得到与enter()相关的错误,我无法理解为什么`svg.append("g").append("g").attr("class","节点");` (2认同)