Simple D3 demo not working with altered structure

前端 未结 1 430
面向向阳花
面向向阳花 2021-01-27 05:32

I was following the official tutorial. Since the structure was pretty rudimentary I decided to do a cleaner one:



&         


        
相关标签:
1条回答
  • 2021-01-27 05:59

    Your script is on the head, and it's being parsed before the div with a class "chart" being generated .

    Just move all your script to the end of the body, after the div you are selecting:

    .chart div {
            font: 10px sans-serif;
            background-color: steelblue;
            text-align: right;
            padding: 3px;
            margin: 1px;
            color: white;
        }
    <body>
    <script src="https://d3js.org/d3.v4.min.js"></script>
    <div class="chart"></div>
    <script>
      var data = [4, 8, 15, 16, 23, 42];
    
        var x = d3.scaleLinear()
            .domain([0, d3.max(data)])
            .range([0, 420]);
    
        d3.select(".chart")
            .selectAll("div")
            .data(data)
        .enter().append("div")
            .style("width", function(d) { return d * 10 + "px"; })
            .text(function(d) { return d; });
      </script>
    </body>

    If you want to keep the script in the head, for whatever reason, just change d3.select(".chart") for d3.select("body"):

    div {
            font: 10px sans-serif;
            background-color: steelblue;
            text-align: right;
            padding: 3px;
            margin: 1px;
            color: white;
        }
    <head>
    <title>D3</title>
    <style>
        .chart div {
            font: 10px sans-serif;
            background-color: steelblue;
            text-align: right;
            padding: 3px;
            margin: 1px;
            color: white;
        }
    </style>
    <script src="https://d3js.org/d3.v4.min.js"></script>
    <script>
    
        var data = [4, 8, 15, 16, 23, 42];
    
        var x = d3.scaleLinear()
            .domain([0, d3.max(data)])
            .range([0, 420]);
    
        d3.select("body")
            .selectAll("div")
            .data(data)
        .enter().append("div")
            .style("width", function(d) { return d * 10 + "px"; })
            .text(function(d) { return d; });
    
    </script>
    </head>
    <body>
    </body>

    0 讨论(0)
提交回复
热议问题