Вы могли бы использовать Series.setData
API для диаграммы Серии, установив опцию updatePoints
на false
, чтобы сделать работу:
function update() {
chart.series[0].setData(percentageDataUpdate, true, true, false);
}
Под Series.update
:
Обратите внимание, что Series.update может изменять параметры передаваемых данных.
И ошибка , которую вы получаете :
Highcharts ожидает сортировки данных
Это происходит при создании ряда линий или графика запасов, где данные не сортируются в порядке возрастания X.
Из соображений производительности Highcharts не сортирует данные, а требует, чтобы разработчик предварительно сортировал данные.
var percentageDataUpdate = [7.142857142857142, 9.090909090909092, 0, 0, 12.5, 33.33333333333333, 33.33333333333333, 50, 0, 7.142857142857142, 7.6923076923076925, 0, 50, 0, 0, 0, 50, 0];
var barData = [{ "name": "A", "y": 56 }, { "name": "B", "y": 44 }, { "name": "C", "y": 8 }, { "name": "D", "y": 8 }, { "name": "E", "y": 32 }, { "name": "F", "y": 12 }, { "name": "G", "y": 12 }, { "name": "H", "y": 8 }, { "name": "I", "y": 8 }, { "name": "J", "y": 56 }, { "name": "K", "y": 52 }, { "name": "L", "y": 12 }, { "name": "M", "y": 16 }, { "name": "N", "y": 8 }, { "name": "O", "y": 8 }, { "name": "P", "y": 8 }, { "name": "Q", "y": 8 }, { "name": "R", "y": 8 } ]
var yAxis = [
{ // Secondary yAxis
title: {
text: 'Error Percentage',
style: {
color: Highcharts.getOptions().colors[0]
}
},
labels: {
format: '{value}',
style: {
color: Highcharts.getOptions().colors[0]
}
},
max: 100,
startOnTick: false,
endOnTick: false,
opposite: true
},
{ // Primary yAxis
title: {
text: ' Average Count',
style: {
color: Highcharts.getOptions().colors[0]
}
},
labels: {
format: '{value} ',
style: {
color: Highcharts.getOptions().colors[0]
}
}
}
];
var chart = Highcharts.chart('container', {
chart: {
type: 'column'
},
title: {
text: 'Error Distribution (Days)'
},
xAxis: {
title: {
text: 'Value Type'
},
type: 'category',
crosshair: true
},
yAxis: yAxis,
series: [{
name: 'Percentage',
type: 'line',
data: [42.857142857142854, 36.36363636363637, 50, 100, 37.5, 66.66666666666666, 66.66666666666666, 50, 50, 21.428571428571427, 23.076923076923077, 33.33333333333333, 75, 100, 100, 50, 100, 50],
color: "#FFA500"
},
{
name: "Count Distribution by Types",
type: 'column',
yAxis: 1,
data: barData,
color: "#7cb5ec"
},
]
});
function update() {
chart.series[0].setData(percentageDataUpdate, true, true, false);
}
.highcharts-figure,
.highcharts-data-table table {
min-width: 310px;
max-width: 800px;
margin: 1em auto;
}
#container {
height: 400px;
}
.highcharts-data-table table {
font-family: Verdana, sans-serif;
border-collapse: collapse;
border: 1px solid #EBEBEB;
margin: 10px auto;
text-align: center;
width: 100%;
max-width: 500px;
}
.highcharts-data-table caption {
padding: 1em 0;
font-size: 1.2em;
color: #555;
}
.highcharts-data-table th {
font-weight: 600;
padding: 0.5em;
}
.highcharts-data-table td,
.highcharts-data-table th,
.highcharts-data-table caption {
padding: 0.5em;
}
.highcharts-data-table thead tr,
.highcharts-data-table tr:nth-child(even) {
background: #f8f8f8;
}
.highcharts-data-table tr:hover {
background: #f1f7ff;
}
<script src="https://code.highcharts.com/highcharts.js"></script>
<script src="https://code.highcharts.com/modules/data.js"></script>
<script src="https://code.highcharts.com/modules/drilldown.js"></script>
<script src="https://code.highcharts.com/modules/exporting.js"></script>
<script src="https://code.highcharts.com/modules/export-data.js"></script>
<script src="https://code.highcharts.com/modules/accessibility.js"></script>
<figure class="highcharts-figure">
<div id="container"></div>
<input type="button" onClick="update()" value="Submit" />
</figure>
Хак: если вам действительно нужно использовать обновление, сделайте это дважды:
function update() {
chart.series[0].update({ data: [] });
chart.series[0].update({ data: percentageDataUpdate });
}
var percentageDataUpdate = [7.142857142857142, 9.090909090909092, 0, 0, 12.5, 33.33333333333333, 33.33333333333333, 50, 0, 7.142857142857142, 7.6923076923076925, 0, 50, 0, 0, 0, 50, 0];
var barData = [{ "name": "A", "y": 56 }, { "name": "B", "y": 44 }, { "name": "C", "y": 8 }, { "name": "D", "y": 8 }, { "name": "E", "y": 32 }, { "name": "F", "y": 12 }, { "name": "G", "y": 12 }, { "name": "H", "y": 8 }, { "name": "I", "y": 8 }, { "name": "J", "y": 56 }, { "name": "K", "y": 52 }, { "name": "L", "y": 12 }, { "name": "M", "y": 16 }, { "name": "N", "y": 8 }, { "name": "O", "y": 8 }, { "name": "P", "y": 8 }, { "name": "Q", "y": 8 }, { "name": "R", "y": 8 } ]
var yAxis = [
{ // Secondary yAxis
title: {
text: 'Error Percentage',
style: {
color: Highcharts.getOptions().colors[0]
}
},
labels: {
format: '{value}',
style: {
color: Highcharts.getOptions().colors[0]
}
},
max: 100,
startOnTick: false,
endOnTick: false,
opposite: true
},
{ // Primary yAxis
title: {
text: ' Average Count',
style: {
color: Highcharts.getOptions().colors[0]
}
},
labels: {
format: '{value} ',
style: {
color: Highcharts.getOptions().colors[0]
}
}
}
];
var chart = Highcharts.chart('container', {
chart: {
type: 'column'
},
title: {
text: 'Error Distribution (Days)'
},
xAxis: {
title: {
text: 'Value Type'
},
type: 'category',
crosshair: true
},
yAxis: yAxis,
series: [{
name: 'Percentage',
type: 'line',
data: [42.857142857142854, 36.36363636363637, 50, 100, 37.5, 66.66666666666666, 66.66666666666666, 50, 50, 21.428571428571427, 23.076923076923077, 33.33333333333333, 75, 100, 100, 50, 100, 50],
color: "#FFA500"
},
{
name: "Count Distribution by Types",
type: 'column',
yAxis: 1,
data: barData,
color: "#7cb5ec"
},
]
});
function update() {
chart.series[0].update({ data: [] });
chart.series[0].update({ data: percentageDataUpdate });
}
.highcharts-figure,
.highcharts-data-table table {
min-width: 310px;
max-width: 800px;
margin: 1em auto;
}
#container {
height: 400px;
}
.highcharts-data-table table {
font-family: Verdana, sans-serif;
border-collapse: collapse;
border: 1px solid #EBEBEB;
margin: 10px auto;
text-align: center;
width: 100%;
max-width: 500px;
}
.highcharts-data-table caption {
padding: 1em 0;
font-size: 1.2em;
color: #555;
}
.highcharts-data-table th {
font-weight: 600;
padding: 0.5em;
}
.highcharts-data-table td,
.highcharts-data-table th,
.highcharts-data-table caption {
padding: 0.5em;
}
.highcharts-data-table thead tr,
.highcharts-data-table tr:nth-child(even) {
background: #f8f8f8;
}
.highcharts-data-table tr:hover {
background: #f1f7ff;
}
<script src="https://code.highcharts.com/highcharts.js"></script>
<script src="https://code.highcharts.com/modules/data.js"></script>
<script src="https://code.highcharts.com/modules/drilldown.js"></script>
<script src="https://code.highcharts.com/modules/exporting.js"></script>
<script src="https://code.highcharts.com/modules/export-data.js"></script>
<script src="https://code.highcharts.com/modules/accessibility.js"></script>
<figure class="highcharts-figure">
<div id="container"></div>
<input type="button" onClick="update()" value="Submit" />
</figure>