Highcharts更新图表滚动问题 - 滚动到初始位置

时间:2018-03-09 21:39:08

标签: highcharts highstock highcharts-ng angular2-highcharts

我遇到了Highcharts highstock柱形图的问题。使用xaxis min = 0,max = 5 [page size],它有20个类别。 在初始加载后,将xaxis滚动到最后,然后单击修改数据。在这个动作上,我将调用一个api并更新系列数据。 '即使有一个类别,图表也会显示为无数据显示'。我想重置滚动到初始位置,这是我不能为类别做的。您需要手动移动滚动

此外,由于只有一个类别,我不希望其他类别显示为数字。 https://jsfiddle.net/shashi3337/zcf8kvgx/7/

我正在更新图表以修改xaxis min和max以将max设置为0 [1 category]以删除数字。 https://jsfiddle.net/shashi3337/zcf8kvgx/5/

现在,当您单击添加数据时,会添加数据。我正在重置min = 0和max = 5。现在 我只看到每页滚动一个类别。

预期行为 我希望滚动条在我单击修改数据按钮后自动滚动回来,当我点击添加数据按钮时,我希望在x轴上每页滚动6个类别。

function test(n) {
  var data = [];
  for (var i = 0; i < n; i++) {
    var value = Math.random() * 10;
    var x = {
      id: i,
      name: 'test ' + i,
      y: value
    }
    data.push(x);
  }
  return data;
}

var chart = Highcharts.chart('container', {
  chart: {
    type: 'column',
  },
  plotOptions: {
    column: {
      stacking: 'normal'
    },
  },
  xAxis: {
    type: 'category',
    min:0,
    max:5
  },
  scrollbar: {
    enabled: true
  },
  series: [{
      name: "A",
      data: test(20)
    }, {
      name: "B",
      data: test(20)
    },
    {
      name: "C",
      data: test(20)
    },
    {
      name: "D",
      data: test(20)
    }
  ]
});


$(document).ready(function(){
  $('#modify').click(function(){
   if(chart){
    while (chart.series.length > 0)
         chart.series[0].remove(true);


     chart.addSeries({
     name: 'new',
        data: test(1)
     });
    }
  });

  $('#add').click(function(){
   if(chart){
    while (chart.series.length > 0)
         chart.series[0].remove(true);

    chart.update({
      xAxis: {
        min:0,
        max:5
        }
     });

     chart.addSeries({
     name: 'A',
        data: test(20)
     });
    }
  });
});

1 个答案:

答案 0 :(得分:0)

找到答案。

您需要使用xAxis.setExtremes()来修改图表上的极值。此时,用户设置的极值(例如通过滚动条)具有最高优先级,并且在删除所有系列时不会清除。

示例https://jsfiddle.net/BlackLabel/pp2qpxks/

 chart.xAxis[0].setExtremes(0, 0);