データをページングするために配列スライスを使用しています。最後のページ (要素が 10 ではなく 7 つしかないページ) に到達すると、最後の 3 つのバーを削除できません。.exit().remove() はページの他の要素では機能しますが、何らかの理由でバーでは機能しません。最後のページのバー 8 ~ 10 を削除するにはどうすればよいですか?
jsfiddle の例を次に示します: http://jsfiddle.net/PMEAT/1/
jsfiddle のコードは次のとおりです。
var data = [1,1,1,1,1,1,1,1,6,7,3,3,3,3,3,3,3];
var chart = d3.select("body").append("svg")
.attr("class","chart")
.attr("width",440)
.attr("height",300);
var barnumber = 10;
var page = 1;
var y = d3.scale.linear()
.domain([0,10])
.range([0,300])
var viewdata = data.slice((page-1)*barnumber,page*barnumber);
var rect = chart.selectAll("rect")
.data(viewdata);
rect.enter().insert("rect")
.attr("x",function(d,i){ return i*20})
.attr("y",function(d) {return 300 - y(d);})
.attr("width", 20)
.attr("height", y);
chart.selectAll("text")
.data(viewdata)
.enter().append("text")
.attr("x", function(d,i) { return i*20+8; })
.attr("y", 290)
.text(String);
$('#next').click(function() {
page++;
viewdata = data.slice((page-1)*barnumber,page*barnumber);
redraw();
});
$('#last').click(function() {
page--;
viewdata = data.slice((page-1)*barnumber,page*barnumber);
redraw();
});
function redraw() {
rect.data(viewdata)
.transition()
.duration(500)
.attr("x",function(d,i){ return i*20})
.attr("y",function(d) {return 300 - y(d);})
.attr("width", 20)
.attr("height", y);
chart.selectAll("text")
.data(viewdata)
.transition()
.duration(500)
.text(String);
rect.exit().remove();
}