私の質問は、 JS D3 textPath が表示されないのと非常によく似ています
1つの違いは、ノードだけでなくリンクに戻るjsonを添付したいことです(親にリンクするすべてのノードについて、そのリンクに同じjsonを持たせたい)...そして理想的には、実際にはルートノードから左に行を追加したいだけでなく、どこにも行きません。
それから、私は基本的にリンクの途中にテキストを入れたいと思っています。リンク行をたどるのはいいことですが、絶対に必要というわけではありません。
私の現在の非動作コードは(よくわかりませんが、各リンクにid要素を追加する必要がありますか?しかし、そのためにはjsonが必要です!!!!さらに、テキストを取得するにはjsonが必要です各リンクについても)、間違っていなければパスを参照するために textPath の id を使用すると思いますよね?
var width = $("#graph").width(),
height = 200;
var cluster = d3.layout.cluster()
.size([height, width - 160]);
var diagonal = d3.svg.diagonal()
.projection(function(d) { return [d.y, d.x]; });
var myDiv = document.getElementById('graph');
var svg = d3.select(myDiv).append("svg")
.attr("width", width)
.attr("height", height)
.append("g")
.attr("transform", "translate(40,0)");
d3.json("/datastreams/json/${_encoded}", function(error, root) {
var nodes = cluster.nodes(root),
links = cluster.links(nodes);
var link = svg.selectAll(".link")
.data(links)
.enter().append("path")
.attr("class", "link")
.attr("d", diagonal);
var node = svg.selectAll(".node")
.data(nodes)
.enter().append("g")
.attr("class", "node")
.attr("transform", function(d) { return "translate(" + d.y + "," + d.x + ")"; })
link.append("text")
.style("font-size", function(d) { return d.selected ? "16px" : "10px"; })
.style("font-weight", function(d) { return d.selected ? "bold" : ""; })
.text(function(d) { return "SSSS="+d.name; });
node.append("circle")
.attr("r", function(d) { return d.selected ? 10 : 4.5; });
var refs = node.append("a")
.attr("xlink:href", function(d) { return d.root ? "start" : "end"; });
var text = refs.append("text")
.attr("dx", function(d) { return d.root ? 8 : -8; })
.attr("dy", -4)
.style("text-anchor", function(d) { return d.root ? "start" : "end"; });
text.append("tspan")
.style("font-size", function(d) { return d.selected ? "16px" : "10px"; })
.style("font-weight", function(d) { return d.selected ? "bold" : ""; })
.style("fill", function(d) { return "blue"; })
.text(function(d) { return d.name; });
});
d3.select(self.frameElement).style("height", height + "px");
</script>