gpt4 book ai didi

javascript - D3 : How can I change data in an existing bar chart

转载 作者:塔克拉玛干 更新时间:2023-11-02 20:27:01 24 4
gpt4 key购买 nike

我已经成功构建了我的初始条形图。现在我想使用过渡向现有图表添加更多条形以获得良好的用户体验。

这是我的代码:

var data = [23, 85, 67, 38, 70]; //dummy, normally much more
labellist = ['label1','label2','label3','label4','label5'];

var w = 815,
h = 500,
labelpad = 165,
x = d3.scale.linear().domain([0, 100]).range([0, w]),
y = d3.scale.ordinal().domain(d3.range(data.length)).rangeBands([0, h], .2);

mySvg = d3.select("#chart")
.append("svg");

vis = mySvg.attr("width", w + 40)
.attr("height", h + 20)
.append("svg:g")
.attr("transform", "translate(20,0)");

bars = vis.selectAll("g.bar")
.data(data)
.enter().append("svg:g")
.attr("class", "bar")
.attr("transform", function(d, i) { return "translate(" + labelpad + "," + y(i) + ")"; })


bars.append("svg:rect")

.transition()
.duration(500)
.attr("width", x)
.attr("height", y.rangeBand())
;



var rules = vis.selectAll("g.rule")
.data(x.ticks(10))
.enter().append("svg:g")
.attr("class", "rule")
.attr("transform", function(d) { return "translate(" + x(d) + ", 0)"; });

rules.append("svg:line")
.attr("y1", h)
.attr("y2", h + 6)
.attr("x1", labelpad)
.attr("x2", labelpad)
.attr("stroke", "black");
rules.append("svg:line")
.attr("y1", 0)
.attr("y2", h)
.attr("x1", labelpad)
.attr("x2", labelpad)
.attr("stroke", "white")
.attr("stroke-opacity", .3);

我如何以编程方式更改数据以添加和删除其他条形图并让现有的条形图向上/向下滑动?

最佳答案

您需要为条形数据分配某种形式的键,以便 d3 可以识别前一组中存在的那些。默认是基于索引的,这可能是您想要的。

就过渡而言,您想将代码更改为如下内容:

bars = vis.selectAll("g.bar")
.data(data);

bars.enter().append("svg:g")
.attr("class", "bar")
.append("svg:rect").

bars.transition().duration(500)
.attr("transform", function(d, i) {
return "translate(" + labelpad + "," + y(i) + ")";
})
.selectAll("svg:rect")
.attr("width", x)
.attr("height", y.rangeBand())
;

bars.exit().transition().duration(500)
.selectAll("svg:rect")
.attr("height", 0)
.remove();

“enter()”函数最适合用于立即创建结构。然后使用初始选择对象(条)将新数据应用于所有元素。

您可能还想删除任何过时的栏。在这里,我将它们的大小调整为 0,然后将其删除,但您可以修改它以获得您想要的效果。

关于javascript - D3 : How can I change data in an existing bar chart,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12165021/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com