d3.js 解决——元素覆盖

本文探讨了d3.js中元素覆盖导致的交互事件问题,特别是在气泡图场景下。针对具有共同parent元素和不同parent元素的情况,提出了通过排序DOM结构来解决覆盖问题的方法,并给出了相关示例和注意事项。
摘要由CSDN通过智能技术生成

元素覆盖最常见的应该是在气泡图中
然而数据的不可控+手势交互难免会碰到A元素被B元素覆盖使其无法触发交互事件;
如下svg中各《circle》都被添加了事件,但因为最大的circle在最后才生成,从而使其其他元素的交互事件被遮挡

height="350" width="350" src="https://lhstock.github.io/home/contents/D3/v3/float_1.html" allowfullscreen="">

最初遇到这样的问题时再加上听说svg不支持浮动之类的说法。就暂时把问题存起来了。

情况一:具有共同parent元素时

更改dom结构
array.sort()相信大家都用过。然而这个就是解决的关键;
1.选择所有circle
var circle = d3.selectAll("circle")

2.circle选择集就是个数组啦。v4版本好像是对象——circle.updata才是数组。。记不清了。错了请忽略
circle.sort(function(a,b){
...
})

这里摆两个例子针对不同数据结构的处理demo自行查看源码

height="350" width="350" src="https://lhstock.github.io/home/contents/D3/v3/float_2.html" allowfullscreen="
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值