D3ライブラリを使用してSVG要素をzオーダーの最上位に移動する効果的な方法は何ですか?
私の特定のシナリオは、マウスが特定の部分の上にあるときに(にを追加strokeしてpath)強調表示する円グラフです。チャートを生成するためのコードブロックは次のとおりです。
svg.selectAll("path")
    .data(d)
  .enter().append("path")
    .attr("d", arc)
    .attr("class", "arc")
    .attr("fill", function(d) { return color(d.name); })
    .attr("stroke", "#fff")
    .attr("stroke-width", 0)
    .on("mouseover", function(d) {
        d3.select(this)
            .attr("stroke-width", 2)
            .classed("top", true);
            //.style("z-index", 1);
    })
    .on("mouseout", function(d) {
        d3.select(this)
            .attr("stroke-width", 0)
            .classed("top", false);
            //.style("z-index", -1);
    });
私はいくつかのオプションを試しましたが、今のところ運がありません。両方の使用style("z-index")と呼び出しclassedは機能しませんでした。
「トップ」クラスは、私のCSSでは次のように定義されています。
.top {
    fill: red;
    z-index: 100;
}
このfillステートメントは、正しくオン/オフになっていることを確認するためのものです。です。
使用sortはオプションだと聞きましたが、「選択された」要素を一番上に表示するためにどのように実装されるかはわかりません。
更新:
次のコードで特定の状況を修正しました。このコードは、mouseoverイベントのSVGに新しいアークを追加して、ハイライトを表示します。
svg.selectAll("path")
    .data(d)
  .enter().append("path")
    .attr("d", arc)
    .attr("class", "arc")
    .style("fill", function(d) { return color(d.name); })
    .style("stroke", "#fff")
    .style("stroke-width", 0)
    .on("mouseover", function(d) {
        svg.append("path")
          .attr("d", d3.select(this).attr("d"))
          .attr("id", "arcSelection")
          .style("fill", "none")
          .style("stroke", "#fff")
          .style("stroke-width", 2);
    })
    .on("mouseout", function(d) {
        d3.select("#arcSelection").remove();
    });