height="350" width="350" src="https://lhstock.github.io/home/contents/D3/v3/float_1.html" allowfullscreen="">元素覆盖最常见的应该是在气泡图中
然而数据的不可控+手势交互难免会碰到A元素被B元素覆盖使其无法触发交互事件;
如下svg中各《circle》都被添加了事件,但因为最大的circle在最后才生成,从而使其其他元素的交互事件被遮挡
最初遇到这样的问题时再加上听说svg不支持浮动之类的说法。就暂时把问题存起来了。
情况一:具有共同parent元素时
更改dom结构
height="350" width="350" src="https://lhstock.github.io/home/contents/D3/v3/float_2.html" allowfullscreen="
array.sort()相信大家都用过。然而这个就是解决的关键;
1.选择所有circle
var circle = d3.selectAll("circle")
2.circle选择集就是个数组啦。v4版本好像是对象——circle.updata才是数组。。记不清了。错了请忽略
circle.sort(function(a,b){
...
})
这里摆两个例子针对不同数据结构的处理demo自行查看源码