我遇到了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)
});
}
});
});
答案 0 :(得分:0)
找到答案。
您需要使用xAxis.setExtremes()来修改图表上的极值。此时,用户设置的极值(例如通过滚动条)具有最高优先级,并且在删除所有系列时不会清除。
示例https://jsfiddle.net/BlackLabel/pp2qpxks/
chart.xAxis[0].setExtremes(0, 0);