gpt4 book ai didi

chart.js - 如何在 chartjs 中排序、插入和更新完整数据集?

转载 作者:行者123 更新时间:2023-12-01 10:39:28 30 4
gpt4 key购买 nike

我有几个简单的更新方法无法解决的 chartjs 问题。

我想知道是否可以选择:

  1. 轻松地对数据集进行排序;
  2. 在两点之间插入一些数据;
  3. 重新加载整个图表而不用替换 Canvas 全新的图表?

最佳答案

没有内置选项,但使用 Chart.js 提供的 addDataremoveData 方法编写您自己的选项非常容易。

var MyBarChartMethods = {
// sort a dataset
sort: function (chart, datasetIndex) {
var data = []
chart.datasets.forEach(function (dataset, i) {
dataset.bars.forEach(function (bar, j) {
if (i === 0) {
data.push({
label: chart.scale.xLabels[j],
values: [bar.value]
})
} else
data[j].values.push(bar.value)
});
})

data.sort(function (a, b) {
if (a.values[datasetIndex] > b.values[datasetIndex])
return -1;
else if (a.values[datasetIndex] < b.values[datasetIndex])
return 1;
else
return 0;
})

chart.datasets.forEach(function (dataset, i) {
dataset.bars.forEach(function (bar, j) {
if (i === 0)
chart.scale.xLabels[j] = data[j].label;
bar.label = data[j].label;
bar.value = data[j].values[i];
})
});
chart.update();
},
// reload data
reload: function (chart, datasetIndex, labels, values) {
var diff = chart.datasets[datasetIndex].bars.length - values.length;
if (diff < 0) {
for (var i = 0; i < -diff; i++)
chart.addData([0], "");
} else if (diff > 0) {
for (var i = 0; i < diff; i++)
chart.removeData();
}

chart.datasets[datasetIndex].bars.forEach(function (bar, i) {
chart.scale.xLabels[i] = labels[i];
bar.value = values[i];
})
chart.update();
}
}

你这样调用它(myBarChart 是你的图表)

// sort
MyBarChartMethods.sort(myBarChart, 0)
// reload - same number of values
MyBarChartMethods.reload(myBarChart, 0, ["J", "F", "M", "A", "M", "J", "J"], [1, 2, 3, 4, 5, 6, 7])
// reload - more values
MyBarChartMethods.reload(myBarChart, 0, ["J", "F", "M", "A", "M", "J", "J", "A"], [1, 2, 3, 4, 5, 6, 7, 8])
// reload - less values
MyBarChartMethods.reload(myBarChart, 0, ["J", "F", "M", "A", "M"], [1, 2, 3, 4, 5])

插入 2 个点是 reload 的特例,所以你可以使用相同的函数(或者很容易地根据它编写你自己的函数)


fiddle - http://jsfiddle.net/Lkdxxkfa/

关于chart.js - 如何在 chartjs 中排序、插入和更新完整数据集?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31399991/

30 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com