gpt4 book ai didi

chart.js - 每栏的水平线

转载 作者:行者123 更新时间:2023-12-05 02:52:14 24 4
gpt4 key购买 nike

我正在尝试使用 chart.js 2.9.2 使用 2 个数据集(实际、目标)绘制每个 strip 水平线的图表,如下所示:

enter image description here

但没有成功...这可能吗?

最佳答案

您可以将目标值转换为 float 条,其中使用语法 [min, max] 指定各个条。给定一个名为 targetData 的值数组,它可以用 Array.map() 转换如下。

targetData.map(v => [v - 1, v + 1])

此外,您需要为两个数据集定义单独的堆叠 xAxis。为了在工具提示中显示原始目标值,toolips.callback.label还需要函数。

请查看下面的可运行代码片段。

const actualData = [100, 180, 120, 80, 140, 170, 160];
const targetData = [110, 150, 140, 100, 120, 110, 170];

new Chart("chart", {
type: "bar",
data: {
labels: ["KPI 1", "KPI 2", "KPI 3", "KPI 4", "KPI 5", "KPI 6", "KPI 7"],
datasets: [{
label: "Actual",
backgroundColor: 'rgba(0, 0, 255, 0.2)',
data: actualData,
xAxisID: "x-axis-actual"
},
{
label: "Target",
backgroundColor: 'rgba(255, 0, 128, 1)',
data: targetData.map(v => [v - 1, v + 1]),
xAxisID: "x-axis-target"
}
]
},
options: {
tooltips: {
callbacks: {
label: (tooltipItem, data) => {
const v = data.datasets[tooltipItem.datasetIndex].data[tooltipItem.index];
return Array.isArray(v) ? (v[1] + v[0]) / 2 : v;
}
}
},
scales: {
xAxes: [{
id: "x-axis-target",
stacked: true
},
{
display: false,
offset: true,
stacked: true,
id: "x-axis-actual",
gridLines: {
offsetGridLines: true
}
}
],
yAxes: [{
ticks: {
beginAtZero: true
}
}]
}
}
});
<script src="https://cdnjs.cloudflare.com/ajax/libs/Chart.js/2.9.3/Chart.min.js"></script>
<canvas id="chart" height="120"></canvas>

关于chart.js - 每栏的水平线,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62711919/

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