Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/svg/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
SVG元素重叠问题_Svg_D3.js - Fatal编程技术网

SVG元素重叠问题

SVG元素重叠问题,svg,d3.js,Svg,D3.js,我目前正在使用d3.js进行可视化。请看一看。这是一个dropbox链接,您可能必须允许它加载 我创建了一个函数,在该函数中,当鼠标悬停在地图上的一个点上时,每个重叠元素的大小都会增加 请尝试以下用例: 1.点击美国以放大该国。 2.拖动并平移到纽约,然后将鼠标指针悬停在圆点上 如果一切顺利,你会看到一个巨大的圆圈,里面有多个同心圆。它们都是特定坐标处的重叠元素 我面临的问题是,当SVG元素的大小增加时,其他城市的点会重叠在同心圆的顶部 我的问题是:如何使圆圈(我将鼠标悬停在上方)出现在SVG画

我目前正在使用d3.js进行可视化。请看一看。这是一个dropbox链接,您可能必须允许它加载

我创建了一个函数,在该函数中,当鼠标悬停在地图上的一个点上时,每个重叠元素的大小都会增加

请尝试以下用例: 1.点击美国以放大该国。 2.拖动并平移到纽约,然后将鼠标指针悬停在圆点上

如果一切顺利,你会看到一个巨大的圆圈,里面有多个同心圆。它们都是特定坐标处的重叠元素

我面临的问题是,当SVG元素的大小增加时,其他城市的点会重叠在同心圆的顶部


我的问题是:如何使圆圈(我将鼠标悬停在上方)出现在SVG画布上,这样就看不到这样的点。

最终的解决方案是将SVG元素附加到鼠标上方。这会将元素堆叠在SVG画布的最顶部,并在鼠标移出时将其移除。目前没有z索引替代SVG元素。

解决方案最终是在鼠标上方附加SVG元素。这会将元素堆叠在SVG画布的最顶部,并在鼠标移出时将其移除。目前没有SVG元素的z索引替代品。

您可以通过直接抓取DOM节点并将其放在顶部来实现:

this.parentNode.appendChild(this);

下面是一个示例:

您可以通过直接抓取DOM节点并将其放在顶部来完成此操作:

this.parentNode.appendChild(this);

下面是一个示例:

如果对生成和更新的数据元素使用此方法,则可能需要使用data函数的第二个参数将DOM元素绑定到特定的数据段,否则下次更改数据时可能会出现意外行为。docs:这种方法有一个问题。如果存在该SVG节点的单击或双击事件的任何侦听器,则WebKit浏览器当前会在FireFox浏览器继续运行时停止触发这些事件。如果将此方法用于生成和更新的数据元素,则可能需要使用data函数的第二个参数将DOM元素绑定到特定的数据段,否则下次更改数据时可能会出现意外行为。docs:这种方法有一个问题。如果存在该SVG节点的单击或双击事件的任何侦听器,则WebKit浏览器当前会在FireFox浏览器继续运行时停止触发这些事件。