如何选择 d3 中的前两个元素并对它们应用过渡?

Sag*_*gar 2 javascript svg d3.js

我想在 svg 中选择前两个矩形并对它们应用过渡。我怎样才能做到这一点?

<svg width="1000px" height="500px" style="border:1px solid #AAA;"></svg>
<input type="button" value="Start" id="startTransition">

var dataArray = [5,10,20,30,40,50,60,70,80,90];
var baseLineYposition = 200;

var getY = function(value){
    return baseLineYposition - value;
};

var canvas = d3.select("svg");

var bars = canvas.selectAll("rect")
.data(dataArray)
.enter()
    .append("rect")
    .attr("width",30)
    .attr("height",function(d){return d;})
    .attr("x",function(d,i){return i * 50;})
    .attr("y",function(d,i){return getY(d);});


$(document).ready(function(){
    $("body").on("click","#startTransition",function(){

        var rect1 = d3.selectAll("rect")[0][0];
        var rect2 = d3.selectAll("rect")[0][1];

        rect1.transition().attr("x",200);
        rect2.transition().attr("x",300);
    });
});
Run Code Online (Sandbox Code Playgroud)

此代码给出以下错误。

 rect1.transition is not a function
Run Code Online (Sandbox Code Playgroud)

Lar*_*off 6

我会选择所有元素,然后过滤掉你不想要的元素:

var rects = d3.selectAll("rect")
              .filter(function(d, i) { return i == 0 || i == 1; });

rects.transition()...
Run Code Online (Sandbox Code Playgroud)