gpt4 book ai didi

javascript - D3js : Dropdown update in bar chart

转载 作者:行者123 更新时间:2023-11-30 06:10:30 25 4
gpt4 key购买 nike

我正在使用 d3js 从 .csv 文件构建条形图,由于我的编程知识并不好,我从网上获得了一个示例并开始工作。我可以从 .csv 文件中获取特定值。 csv 并绘制图表,但我想实现一个下拉列表以从 .csv 中选择特定值,如下图所示。

Imagem:

我无法从 .csv 加载此数据。看起来并不复杂,但是我尝试了一些方法并没有成功。有人可以给我任何有关如何执行此操作的提示吗?

最好的问候!

  1. .csv文件
country,year,hdi,gdp,unemp
Australia,2000,45,5.6,9
Austria,2000,54,6.1,8
Canada,2000,23,4.5,6
...
...
  1. HTML + JS
    <html>
<head>
<style>
.bar {
fill: steelblue;
}

.bar:hover {
fill: brown;
}
</style>
<script src="//d3js.org/d3.v5.min.js"></script>
</head>
<body>
<div>
<select id="S_indicators"></select>
</div>

<svg width="560" height="300"></svg>

<script>

var svg = d3.select("svg"),
margin = {
top: 20,
right: 20,
bottom: 30,
left: 50
},
width = +svg.attr("width") - margin.left - margin.right,
height = +svg.attr("height") - margin.top - margin.bottom,
g = svg.append("g").attr("transform", "translate(" + margin.left + "," + margin.top + ")");

var parseTime = d3.timeParse("%d-%b-%y");

var x = d3.scaleBand()
.rangeRound([0, width])
.padding(0.1);

var y = d3.scaleLinear()
.rangeRound([height, 0]);

d3.csv("output.csv").then(function (data) {

var allGroup = ["gdp","hdi","unemp"]

d3.select("#S_indicators")
.selectAll('myOptions')
.data(allGroup)
.enter()
.append('option')
.text(function (d) { return d; })
.attr("value", function (d) { return d; })

x.domain(data.map(function (d) {
return d.year;
}));
y.domain([0, d3.max(data, function (d) {
return Math.max(d.unemp);
})]);

g.append("g")
.attr("transform", "translate(0," + height + ")")
.call(d3.axisBottom(x))

g.append("g")
.call(d3.axisLeft(y))
.append("text")
.attr("fill", "#000")
.attr("transform", "rotate(-90)")
.attr("y", 6)
.attr("dy", "0.71em")
.attr("text-anchor", "end")

g.selectAll(".bar")
.data(data)
.enter().append("rect")
.attr("class", "bar")
.attr("x", function (d) {
return x(d.year);
})
.attr("y", function (d) {
return y(Number(d.unemp));
})
.attr("width", x.bandwidth())
.attr("height", function (d) {
return height - y(Number(d.unemp));
});
});
</script>
</body>
</html>

最佳答案

-在html文件中添加一个下拉列表(我将其命名为dd):

<!DOCTYPE html>
<html lang="en">
<title>My Scatter2</title>
<body>
<select id="dd"></select>
<div id="wrap"></div>
<script src="https://d3js.org/d3.v5.js"></script>
<script src="scatterplot.js"></script>
<link rel='stylesheet' href='styles.css'>
</body>
</html>

通过以下方式将其填充到 D3 中:

  var specs = ['A','B','C']
var dropdown = d3.select('#dd')
dropdown.selectAll('option')
.data(specs)
.enter().append("option")
.attr("value",d=>d)
.text(d => d)

或者如果你想要一个可观察的例子: https://observablehq.com/@kickout/basic-scatterplot

关于javascript - D3js : Dropdown update in bar chart,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59182177/

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