2 回答

TA貢獻1876條經(jīng)驗 獲得超5個贊
使用一個一個函數(shù)來生成fill的值,比如上面的例子,我們作如下修改,就可以實現(xiàn)不同柱不同顏色了:
var layer = svg.selectAll(".stack")
.data(dataStackLayout)
.enter().append("g")
.attr("class", "stack")
// 注釋掉下面代碼
/* .style("fill", function (d, i) {
return color(i);
}); */
layer.selectAll("rect")
.data(function (d) {
return d;
})
.enter().append("rect")
.attr("x", function (d) {
return x(d.x);
})
.attr("y", function (d) {
return y(d.y + d.y0);
})
.attr("height", function (d) {
return y(d.y0) - y(d.y + d.y0);
})
.attr("width", x.rangeBand())
// 增加下面代碼
.style("fill", function (d, i, j) { // 三個參數(shù)分別是:d 數(shù)據(jù),i 當前rect的序號,j 當前rect 的父元素的序號
return color((j * 2) + i);
});
添加回答
舉報