1👍
✅
When the chart.update() is invoked, the chart is re-configuring itself starting from chart.data.datasets
and all element options (changed in the meanwhile) are lost.
The chart.data.datasets
must be changed.
The original backgroundColor
s must be stored because otherwise they will be lost.
const ctx = document.getElementById("myChart");
const backgroundColors = ['rgba(40, 139, 170, 1)', 'rgba(40, 139, 0, 1)'];
const myChart = new Chart(ctx, {
type: 'bar',
data: {
labels: ['January', 'Fabruary', 'March', 'April', 'May', 'June', 'July'],
datasets: [{
label: 'user 1 online',
data: [50, 35, 45, 47, 10, 3, 27],
backgroundColor: backgroundColors[0],
borderWidth: 0,
borderSkipped: 'start'
},
{
label: 'user 2 online',
data: [50, 35, 45, 47, 10, 3, 27],
backgroundColor: backgroundColors[1],
borderWidth: 0,
borderSkipped: 'start'
}]
},
options: {
plugins: {
legend: {
display: true,
position: 'right',
onClick: function (e, legendItem, legend) {
const index = legendItem.datasetIndex;
const ci = legend.chart;
const dataset = ci.data.datasets[index];
if (!dataset.checked) {
dataset.backgroundColor = 'rgba(255, 159, 64, 1)';
dataset.borderWidth = 2;
dataset.borderColor = 'rgba(0,0,0, 1)';
dataset.checked = true;
} else {
dataset.backgroundColor = backgroundColors[index];
dataset.borderWidth = 0;
dataset.borderColor = null;
dataset.checked = false;
}
ci.update();
}
}
}
}
});
.myChartDiv {
max-width: 600px;
max-height: 400px;
}
<script src="https://cdn.jsdelivr.net/npm/chart.js@3.9.1/dist/chart.min.js"></script>
<html>
<body>
<div class="myChartDiv">
<canvas id="myChart" width="600" height="400"/>
</div>
</body>
</html>
Source:stackexchange.com