Обновить линейную диаграмму (High Charts) после применения фильтра - PullRequest
1 голос
/ 13 марта 2020

У меня есть комбинированная диаграмма с двойной осью Y. У меня есть кнопка отправки, которая при нажатии должна обновить график серии линий. Текущие данные, присутствующие в диаграмме серии линий, равны [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]

, когда я нажимаю кнопку «Отправить» в самом низу, она должна обновить эти данные, чтобы график серии линий (оранжевый на JSFiddle) обновлялся новыми ценности . Я сделал обновление, используя приведенный ниже код, но график не обновляется должным образом

function update(){
var seriesChart = chart.series[0];
seriesChart.update({
data:percentageDataUpdate}); 
}  

Может кто-нибудь подсказать мне, как я могу решить эту проблему.

JSFiddle Link: https://jsfiddle.net/q6ybvpgt/1/

Ответы [ 2 ]

2 голосов
/ 13 марта 2020

Вы могли бы использовать 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>
0 голосов
/ 13 марта 2020

Другое решение, которое я могу предложить, - определить значения x для обновленных данных, которые также будут сортировать данные.

Демо: https://jsfiddle.net/BlackLabel/6zdkxby4/

 var percentageDataUpdate = [{
   x: 0,
   y: 7.142857142857142
 }, {
   x: 1,
   y: 9.090909090909092
 }, {
   x: 2,
   y: 0
 }, {
   x: 3,
   y: 0
 }, {
   x: 4,
   y: 12.5
 }...
 }];
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...