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

使用c3将数据添加到图表中。js公司

  •  2
  • yavg  · 技术社区  · 7 年前

    我有一个图表,我想在其中添加更多的数据,而不替换我的数据,或者用一个。推送或添加一组数据,而不会丢失我以前拥有的数据。

    columns: [
          ['data1', -4,3,4,7,8,9,8,7,3],
          ['data1_x', -5,2,3,4,5,4,3,2,1],
    

    . .

    //I need add the new data withouth remove the previous data
    
    chart.load({
        xs: {
            data1: 'data1_x'
        },
        columns: [
            ["data1_x", 3,6],
            ["data1", 5,8]
        ]
    });
    

    https://jsfiddle.net/aL8xhgpn/

    1 回复  |  直到 7 年前
        1
  •  2
  •   StudioTime    6 年前

    可以将数据移动到数组中

    var data1 = ['data1',-4,3,4,7,8,9,8,7,3];
    var data1_x = ['data1_x', -5,2,3,4,5,4,3,2,1];
    

    并将数据推入其中。

    var data1 = ['data1', -4, 3, 4, 7, 8, 9, 8, 7, 3];
    var data1_x = ['data1_x', -5, 2, 3, 4, 5, 4, 3, 2, 1];
    var chart = c3.generate({
      data: {
        xs: {
          data1: "data1_x",
          data2: "data2_x"
        },
        xSort: false,
        columns: [
          data1,
          data1_x, ['data2', Math.random() * 10, Math.random() * 10, Math.random() * 10, Math.random() * 10, Math.random() * 10, Math.random() * 10],
          ['data2_x', Math.random() * 10, Math.random() * 10, Math.random() * 10, Math.random() * 10, Math.random() * 10, Math.random() * 10]
        ]
    
      },
      axis: {
        x: {
          tick: {
            values: d3.range(-5, 10)
          }
        }
      }
    });
    
    chart.internal.xAxis.g.attr('transform', "translate(0," + chart.internal.y(0) + ")");
    chart.internal.yAxis.g.attr('transform', "translate(" + chart.internal.x(0) + ", 0)");
    data1.push(5)
    data1.push(8)
    data1_x.push(3)
    data1_x.push(6)
    
    
    setTimeout(load, 5000);
    
    function load() {
      chart.load({
        xs: {
          data1: 'data1_x'
        },
        columns: [
          data1_x,
          data1
        ]
      });
    }
    <script src="https://cdnjs.cloudflare.com/ajax/libs/d3/3.5.17/d3.js"></script>
    <link href="https://cdnjs.cloudflare.com/ajax/libs/c3/0.4.18/c3.css" rel="stylesheet" />
    <script src="https://cdnjs.cloudflare.com/ajax/libs/c3/0.4.18/c3.js"></script>
    <div id="chart"></div>