car*_*vil 4 javascript svg d3.js
我正在尝试添加指向此 D3 可视化文本元素的链接:
我希望能够单击“flare”、“analytics”并导航到另一个页面或单击矩形并执行正常操作,即展开子树。
我尝试了一些不起作用的事情:
on 事件我试图向元素添加一个on事件svg:text:
nodeEnter.append("svg:text")
.attr("dy", 3.5)
.attr("dx", 5.5)
.text(function(d) { return d.name; })
.on("click",function(d,i) { alert("Clicked on the text");});
Run Code Online (Sandbox Code Playgroud)
foreignObject 元素我试图添加这样的foreignObject元素:
nodeEnter.append("svg:foreignObject")
.style("float","right")
.attr("height", 100)
.attr("width", 100)
.append("div")
.html("<a href='#'>link</a>")
Run Code Online (Sandbox Code Playgroud)
尽管它创建了链接,但它是一个额外的链接(不是矩形中的文本元素)。
xlink:href属性链接最后,我还尝试了以下(在某些组合中):
<a xlink:href="/svg/index.html">
<text x="10" y="20">/svg/index.html</text>
</a>
Run Code Online (Sandbox Code Playgroud)
但它也没有奏效。
有什么建议?
小智 7
我同意马特的回答:指针事件...pointer-events: all在 css 中将其更改为。
这就是我在力有向图中建立链接的方式:
svg = d3.select("body").append("svg");
svg.selectAll(".node")
.append("svg:a").attr("xlink:href", function(d){ return "generic.php?url=" + d.url })
.append("svg:text")
.text(function(d) { return d.name; })
.attr("dy", 3.5)
.attr("dx", 5.5)
.attr("text-anchor", "middle");
//The End ;-)
Run Code Online (Sandbox Code Playgroud)