代码之家  ›  专栏  ›  技术社区  ›  Jimmy

JavaScript刷新文件内容

  •  0
  • Jimmy  · 技术社区  · 7 年前

    我让D3 JS加载文件的内容(它有CSV值)。但是,文件中的值将更改。在不刷新整个浏览器窗口的情况下,如何才能让它拉入新数据?

    这是我现在的密码:

    <!DOCTYPE html>
    <meta charset="utf-8">
    
    
    <body>
    
    <script src="d3.v3.min.js"></script>
    
    <script>
    
    var margin = {top: 20, right: 20, bottom: 70, left: 40},
        width = 600 - margin.left - margin.right,
        height = 300 - margin.top - margin.bottom;
    
    // Parse the date / time
    var parseDate = d3.time.format("%Y-%m").parse;
    
    var x = d3.scale.ordinal().rangeRoundBands([0, width], .05);
    
    var y = d3.scale.linear().range([height, 0]);
    
    var xAxis = d3.svg.axis()
        .scale(x)
        .orient("bottom")
        .tickFormat(d3.time.format("%Y-%m"));
    
    var yAxis = d3.svg.axis()
        .scale(y)
        .orient("left")
        .ticks(10);
    
    var svg = d3.select("body").append("svg")
        .attr("width", width + margin.left + margin.right)
        .attr("height", height + margin.top + margin.bottom)
      .append("g")
        .attr("transform", 
              "translate(" + margin.left + "," + margin.top + ")");
    
    d3.csv("test2.csv", function(error, data) {
    
        data.forEach(function(d) {
            d.date = parseDate(d.date);
            d.value = +d.value;
        });
    
      x.domain(data.map(function(d) { return d.date; }));
      y.domain([0, d3.max(data, function(d) { return d.value; })]);
    
      svg.append("g")
          .attr("class", "x axis")
          .attr("transform", "translate(0," + height + ")")
          .call(xAxis)
        .selectAll("text")
          .style("text-anchor", "end")
          .attr("dx", "-.8em")
          .attr("dy", "-.55em")
          .attr("transform", "rotate(-90)" );
    
      svg.append("g")
          .attr("class", "y axis")
          .call(yAxis)
        .append("text")
          .attr("transform", "rotate(-90)")
          .attr("y", 6)
          .attr("dy", ".71em")
          .style("text-anchor", "end")
          .text("Value ($)");
    
      svg.selectAll("bar")
          .data(data)
        .enter().append("rect")
          .style("fill", "steelblue")
          .attr("x", function(d) { return x(d.date); })
          .attr("width", x.rangeBand())
          .attr("y", function(d) { return y(d.value); })
          .attr("height", function(d) { return height - y(d.value); });
    
    });
    
    </script>
    
    </body>
    

    我想我可能需要打电话 data.forEach(function(d) 再一次?但我试过:

    <script>
    var int=self.setInterval(data.forEach(function(d), 60000);
    </script>
    
    2 回复  |  直到 7 年前
        1
  •  1
  •   Jim Wright    7 年前

    d3.csv() 将在执行时将文件内容传递给其回调。在回调中循环多少次数据并不重要,它将与循环的数据相同。

    要再次加载数据,应调用 d3.csv() 再次使用新数据调用回调。

    当我将回调提取到一个命名函数并调用 d3.csv 每一分钟。

    <!DOCTYPE html>
    <meta charset="utf-8">
    
    
    <body>
    
    <script src="d3.v3.min.js"></script>
    
    <script>
    
    var margin = {top: 20, right: 20, bottom: 70, left: 40},
        width = 600 - margin.left - margin.right,
        height = 300 - margin.top - margin.bottom;
    
    // Parse the date / time
    var parseDate = d3.time.format("%Y-%m").parse;
    
    var x = d3.scale.ordinal().rangeRoundBands([0, width], .05);
    
    var y = d3.scale.linear().range([height, 0]);
    
    var xAxis = d3.svg.axis()
        .scale(x)
        .orient("bottom")
        .tickFormat(d3.time.format("%Y-%m"));
    
    var yAxis = d3.svg.axis()
        .scale(y)
        .orient("left")
        .ticks(10);
    
    var svg = d3.select("body").append("svg")
        .attr("width", width + margin.left + margin.right)
        .attr("height", height + margin.top + margin.bottom)
      .append("g")
        .attr("transform", 
              "translate(" + margin.left + "," + margin.top + ")");
    
    // Created a reusable function for the callback
    function handleCsvData(error, data) {
    
      data.forEach(function(d) {
          d.date = parseDate(d.date);
          d.value = +d.value;
      });
    
      x.domain(data.map(function(d) { return d.date; }));
      y.domain([0, d3.max(data, function(d) { return d.value; })]);
    
      svg.append("g")
          .attr("class", "x axis")
          .attr("transform", "translate(0," + height + ")")
          .call(xAxis)
          .selectAll("text")
          .style("text-anchor", "end")
          .attr("dx", "-.8em")
          .attr("dy", "-.55em")
          .attr("transform", "rotate(-90)" );
    
      svg.append("g")
          .attr("class", "y axis")
          .call(yAxis)
          .append("text")
          .attr("transform", "rotate(-90)")
          .attr("y", 6)
          .attr("dy", ".71em")
          .style("text-anchor", "end")
          .text("Value ($)");
    
      svg.selectAll("bar")
          .data(data)
          .enter().append("rect")
          .style("fill", "steelblue")
          .attr("x", function(d) { return x(d.date); })
          .attr("width", x.rangeBand())
          .attr("y", function(d) { return y(d.value); })
          .attr("height", function(d) { return height - y(d.value); });
    
    }
    
    // Call d3.csv every minute and pass contents to callback
    var csvReloadInterval = setInterval(d3.csv("test2.csv", handleCsvData), 60000);
    // Call d3.csv for the first time
    d3.csv("test2.csv", handleCsvData);
    
    </script>
    
    </body>
    
        2
  •  1
  •   Andre Nuechter    7 年前

    您必须再次调用d3.csv()来检查更新。
    有关扩展示例,请参见此处:
    http://bl.ocks.org/d3noob/6bd13f974d6516f3e491