繁体   English   中英

D3js:条形图中的下拉更新

[英]D3js: Dropdown update in bar chart

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

图片:

我无法从 .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

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM