ChartJs 显示错误的标签
ChartJs shows the wrong labels
首先,我想说我是一名学习编程一个月左右的学生,所以希望看到很多错误。
我正在使用 ChartJs 库中的图表的网站上工作。我有一个外圈,显示在公司工作的时间和达到月度目标所需的时间。内圈显示该月的天数和该月剩余的天数。这是代码:
const data = {
labels: ['Summe', 'Noch um Ziel zu erreichen', 'Tage', 'Verbleibende Tage im Monat'],
datasets: [
{
backgroundColor: ['#5ce1e6', '#2acaea'],
data: [studenGesamt, (800 - studenGesamt)]
},
{
backgroundColor: ['#cd1076', '#8b0a50'],
data: [dayD, (23 - dayD)]
},
]
};
// Configuration of the pie chart
let outterChart = new Chart(chart, {
type: 'pie',
data: data,
options: {
responsive: true,
plugins: {
legend: {
labels: {
generateLabels: function(chart) {
// Get the default label list
const original = Chart.overrides.pie.plugins.legend.labels.generateLabels;
const labelsOriginal = original.call(this, chart);
// Build an array of colors used in the datasets of the chart
var datasetColors = chart.data.datasets.map(function(e) {
return e.backgroundColor;
});
datasetColors = datasetColors.flat();
// Modify the color and hide state of each label
labelsOriginal.forEach(label => {
// Change the color to match the dataset
label.fillStyle = datasetColors[label.index];
});
return labelsOriginal;
}
},
onClick: function(mouseEvent, legendItem, legend) {
// toggle the visibility of the dataset from what it currently is
legend.chart.getDatasetMeta(
legendItem.datasetIndex
).hidden = legend.chart.isDatasetVisible(legendItem.datasetIndex);
legend.chart.update();
}
},
tooltips: {
callbacks: {
label: function(context) {
const labelIndex = (context.datasetIndex * 2) + context.dataIndex;
return context.chart.data.labels[labelIndex] + ': ' + context.formattedValue;
}
}
},
}
},
});
外圈完成的部分悬停时应该显示标签“Summe: X”,外圈未完成的部分应该显示“Noch um Ziel zu erreichen: X”,并且有效美好的。内圈完成的部分应该显示“Tage: X”,当你悬停它时,内圈未完成的部分应该显示“Verbleibende Tage im Monat: X”,但是没有。
我上周完成了这张图表并且它工作正常,显示了我上面解释的标签,但是当我今天打开它时,它不再以这种方式显示标签。我确实做了一些更改,但据我所知,我还原了所有更改。
这些是图表及其行为的一些图片:
在最后一张图片上,标签应该是“Tage: 6”。数据正确,但标签文本不正确。这种情况也发生在内圈的未完成部分,其中数据是正确的,但它显示与外圈未完成部分相同的标签(“Noch um Ziel zu erreichen”而不是“Verbleibende Tage im Monat” ).正如我所说,这段代码上周运行正常,所以我不确定发生了什么,也无法弄清楚。如果有人能帮助我,我将不胜感激,感谢阅读!
注意:我用于图表的数据是通过对包含 JSON 文件和信息的服务器的请求获取的,然后存储在不同的变量中,如“stundenGesamt”和“dayD” ".
您遇到的错误是您的 tooltip
配置错误,在 v3 中,命名从 tooltips
更改为 tooltip
如果您更改它工作正常:
const data = {
labels: ['Summe', 'Noch um Ziel zu erreichen', 'Tage', 'Verbleibende Tage im Monat'],
datasets: [{
backgroundColor: ['#5ce1e6', '#2acaea'],
data: [200, (800 - 200)]
},
{
backgroundColor: ['#cd1076', '#8b0a50'],
data: [4, (23 - 4)]
},
]
};
var ctx = document.getElementById('chartJSContainer').getContext('2d');
// Configuration of the pie chart
let outterChart = new Chart(ctx, {
type: 'pie',
data: data,
options: {
responsive: true,
plugins: {
legend: {
labels: {
generateLabels: function(chart) {
// Get the default label list
const original = Chart.overrides.pie.plugins.legend.labels.generateLabels;
const labelsOriginal = original.call(this, chart);
// Build an array of colors used in the datasets of the chart
var datasetColors = chart.data.datasets.map(function(e) {
return e.backgroundColor;
});
datasetColors = datasetColors.flat();
// Modify the color and hide state of each label
labelsOriginal.forEach(label => {
// Change the color to match the dataset
label.fillStyle = datasetColors[label.index];
});
return labelsOriginal;
}
},
onClick: function(mouseEvent, legendItem, legend) {
// toggle the visibility of the dataset from what it currently is
legend.chart.getDatasetMeta(
legendItem.datasetIndex
).hidden = legend.chart.isDatasetVisible(legendItem.datasetIndex);
legend.chart.update();
}
},
tooltip: {
callbacks: {
label: function(context) {
const labelIndex = (context.datasetIndex * 2) + context.dataIndex;
return context.chart.data.labels[labelIndex] + ': ' + context.formattedValue;
}
}
},
}
},
});
<body>
<canvas id="chartJSContainer" width="600" height="400"></canvas>
<script src="https://cdnjs.cloudflare.com/ajax/libs/Chart.js/3.5.1/chart.js"></script>
</body>
首先,我想说我是一名学习编程一个月左右的学生,所以希望看到很多错误。
我正在使用 ChartJs 库中的图表的网站上工作。我有一个外圈,显示在公司工作的时间和达到月度目标所需的时间。内圈显示该月的天数和该月剩余的天数。这是代码:
const data = {
labels: ['Summe', 'Noch um Ziel zu erreichen', 'Tage', 'Verbleibende Tage im Monat'],
datasets: [
{
backgroundColor: ['#5ce1e6', '#2acaea'],
data: [studenGesamt, (800 - studenGesamt)]
},
{
backgroundColor: ['#cd1076', '#8b0a50'],
data: [dayD, (23 - dayD)]
},
]
};
// Configuration of the pie chart
let outterChart = new Chart(chart, {
type: 'pie',
data: data,
options: {
responsive: true,
plugins: {
legend: {
labels: {
generateLabels: function(chart) {
// Get the default label list
const original = Chart.overrides.pie.plugins.legend.labels.generateLabels;
const labelsOriginal = original.call(this, chart);
// Build an array of colors used in the datasets of the chart
var datasetColors = chart.data.datasets.map(function(e) {
return e.backgroundColor;
});
datasetColors = datasetColors.flat();
// Modify the color and hide state of each label
labelsOriginal.forEach(label => {
// Change the color to match the dataset
label.fillStyle = datasetColors[label.index];
});
return labelsOriginal;
}
},
onClick: function(mouseEvent, legendItem, legend) {
// toggle the visibility of the dataset from what it currently is
legend.chart.getDatasetMeta(
legendItem.datasetIndex
).hidden = legend.chart.isDatasetVisible(legendItem.datasetIndex);
legend.chart.update();
}
},
tooltips: {
callbacks: {
label: function(context) {
const labelIndex = (context.datasetIndex * 2) + context.dataIndex;
return context.chart.data.labels[labelIndex] + ': ' + context.formattedValue;
}
}
},
}
},
});
外圈完成的部分悬停时应该显示标签“Summe: X”,外圈未完成的部分应该显示“Noch um Ziel zu erreichen: X”,并且有效美好的。内圈完成的部分应该显示“Tage: X”,当你悬停它时,内圈未完成的部分应该显示“Verbleibende Tage im Monat: X”,但是没有。
我上周完成了这张图表并且它工作正常,显示了我上面解释的标签,但是当我今天打开它时,它不再以这种方式显示标签。我确实做了一些更改,但据我所知,我还原了所有更改。
这些是图表及其行为的一些图片:
在最后一张图片上,标签应该是“Tage: 6”。数据正确,但标签文本不正确。这种情况也发生在内圈的未完成部分,其中数据是正确的,但它显示与外圈未完成部分相同的标签(“Noch um Ziel zu erreichen”而不是“Verbleibende Tage im Monat” ).正如我所说,这段代码上周运行正常,所以我不确定发生了什么,也无法弄清楚。如果有人能帮助我,我将不胜感激,感谢阅读!
注意:我用于图表的数据是通过对包含 JSON 文件和信息的服务器的请求获取的,然后存储在不同的变量中,如“stundenGesamt”和“dayD” ".
您遇到的错误是您的 tooltip
配置错误,在 v3 中,命名从 tooltips
更改为 tooltip
如果您更改它工作正常:
const data = {
labels: ['Summe', 'Noch um Ziel zu erreichen', 'Tage', 'Verbleibende Tage im Monat'],
datasets: [{
backgroundColor: ['#5ce1e6', '#2acaea'],
data: [200, (800 - 200)]
},
{
backgroundColor: ['#cd1076', '#8b0a50'],
data: [4, (23 - 4)]
},
]
};
var ctx = document.getElementById('chartJSContainer').getContext('2d');
// Configuration of the pie chart
let outterChart = new Chart(ctx, {
type: 'pie',
data: data,
options: {
responsive: true,
plugins: {
legend: {
labels: {
generateLabels: function(chart) {
// Get the default label list
const original = Chart.overrides.pie.plugins.legend.labels.generateLabels;
const labelsOriginal = original.call(this, chart);
// Build an array of colors used in the datasets of the chart
var datasetColors = chart.data.datasets.map(function(e) {
return e.backgroundColor;
});
datasetColors = datasetColors.flat();
// Modify the color and hide state of each label
labelsOriginal.forEach(label => {
// Change the color to match the dataset
label.fillStyle = datasetColors[label.index];
});
return labelsOriginal;
}
},
onClick: function(mouseEvent, legendItem, legend) {
// toggle the visibility of the dataset from what it currently is
legend.chart.getDatasetMeta(
legendItem.datasetIndex
).hidden = legend.chart.isDatasetVisible(legendItem.datasetIndex);
legend.chart.update();
}
},
tooltip: {
callbacks: {
label: function(context) {
const labelIndex = (context.datasetIndex * 2) + context.dataIndex;
return context.chart.data.labels[labelIndex] + ': ' + context.formattedValue;
}
}
},
}
},
});
<body>
<canvas id="chartJSContainer" width="600" height="400"></canvas>
<script src="https://cdnjs.cloudflare.com/ajax/libs/Chart.js/3.5.1/chart.js"></script>
</body>