gpt4 book ai didi

javascript - 如何通过点击图表栏来改变颜色?

转载 作者:行者123 更新时间:2023-11-30 20:09:33 26 4
gpt4 key购买 nike

我可以使用 onclick 函数实现颜色变化效果,但是我应该遵循以下逻辑:

1) 最后一个柱形总是与其他柱形颜色不同。启动图表就像点击第一个柱形一样。

2) 当点击其他条形时,颜色必须改变,以向用户显示该条形已被点击,但是之前的条形应该恢复到它们的正常颜色..

我对这个逻辑有困难,我正在使用 chartjs 2.x

class ChartVenda {
constructor(_id, _dataJSON){
this.id = _id;
this.dataJSON = _dataJSON;
this.chartElement = document.getElementById(_id).getContext('2d');
}

set chartObject(_object){ this.object = _object; }
get chartObject( ){ return this.object; }

get labels(){
return ['jan', 'fev', 'mar', 'abr', 'mai', 'jun', 'jul', 'ago', 'set', 'out', 'nov', 'dez'];
}

get bgColors(){
return [
'rgb(202, 216, 229)',
'rgb(202, 216, 229)',
'rgb(202, 216, 229)',
'rgb(202, 216, 229)',
'rgb(202, 216, 229)',
'rgb(202, 216, 229)',
'rgb(202, 216, 229)',
'rgb(202, 216, 229)',
'rgb(202, 216, 229)',
'rgb(202, 216, 229)',
'rgb(202, 216, 229)',
'rgb(202, 216, 229)'
]
}

get borderColors(){
return [
'rgba(0,0,0,0.3)',
'rgba(0,0,0,0.3)',
'rgba(0,0,0,0.3)',
'rgba(0,0,0,0.3)',
'rgba(0,0,0,0.3)',
'rgba(0,0,0,0.3)',
'rgba(0,0,0,0.3)',
'rgba(0,0,0,0.3)',
'rgba(0,0,0,0.3)',
'rgba(0,0,0,0.3)',
'rgba(0,0,0,0.3)',
'rgba(0,0,0,0.3)',
]
}

createChart(){
this.generateChart();
this.addChartOptions();
this.addDataJsonInChart();
this.addChartLabels();
this.addChartDatasets();
this.addAnimation();

this.chartObject.update();
console.log(this.chartObject.data.datasets)
}

generateChart(){
let chartVenda = new Chart(this.chartElement, { type: 'bar'});
this.chartObject = chartVenda;
}

addDataJsonInChart(){
this.chartObject.data.dataJSON = this.dataJSON;
}

addChartLabels(){
let counterLabels = 0;
this.dataJSON.records.forEach( () => {
counterLabels += 1;
this.chartObject.data.labels.push(this.labels[counterLabels-1]);
});
}

addChartDatasets(){
let arrDeltaVendam2 = [];
this.dataJSON.records.forEach( (_item) => {
arrDeltaVendam2.push(_item['Δ% Venda m²']);
});

this.chartObject.data.datasets.push({
label: `ae`,
data: arrDeltaVendam2,
backgroundColor: 'rgb(202, 216, 229)',
borderColor: 'rgb(202, 216, 229)',
});

this.chartObject.update();
}

addChartOptions(){
this.chartObject.options = {
responsive: true,
maintainAspectRatio: false,
legend: { display: false },
scales: {
yAxes: [{ ticks: {display: false, fontColor: 'white'}, gridLines: {display: false, drawBorder: false} }],
xAxes: [{ ticks: {fontSize: 15, fontColor: 'white' }, gridLines: {display: false, drawBorder: false} }],
},
onClick: function(_event, _value) {
let datasetIndex,
dataset;

if (_value.length) {
this.chart.data.dataJSON.records.forEach( (item) => {
if(item['Competência'] === _value[0]._model.label){
const VENDA_METROS_TESTE = document.getElementById('primary-jumbotron-subtitle-indicator-m²'),
VENDA_ABS_TESTE = document.getElementById('primary-jumbotron-subtitle-indicator-abs');

VENDA_METROS_TESTE.innerHTML = `${item['Venda m²']} m²`;
VENDA_ABS_TESTE.innerHTML = `${item['Venda']} abs`;
}
});

datasetIndex = _value[0]._datasetIndex;

// Reset old state
dataset = this.chart.data.datasets[datasetIndex];
dataset.backgroundColor = dataset.backgroundColor.slice();
dataset.backgroundColor = 'rgb(133, 222, 252)'; // click color
} else {
// remove hover styles
for (datasetIndex = 0; datasetIndex < myChart.data.datasets.length; ++datasetIndex) {
dataset = this.chart.data.datasets[index];
dataset.backgroundColor = dataset.backgroundColor.slice();
}
}
}
}
}

addAnimation(){
this.chartObject.options.animation = {
duration: 1000,
onProgress: function() {
/** @description <CRIA O EFEITO DE TEXTO EM CIMA DAS BARRAS> **/
const CHART_OBJECT = this.chart;
CHART_OBJECT.ctx.font = Chart.helpers.fontString('17', 'normal', Chart.defaults.global.defaultFontFamily);
CHART_OBJECT.ctx.fillStyle = 'white';
CHART_OBJECT.ctx.textAlign = 'center';
CHART_OBJECT.ctx.textBaseline = 'bottom';
Chart.helpers.each(this.data.datasets.forEach(function (_dataset, _index1) {
Chart.helpers.each(CHART_OBJECT.getDatasetMeta(_index1).data.forEach(function (_bar, _index2) {
let centerPoint = _bar.getCenterPoint();
CHART_OBJECT.ctx.fillText(_dataset.data[_index2], centerPoint.x, centerPoint.y);
}), this);
}), this);
},
}
}


}

最佳答案

我不明白你的第一点,但要解决你的第二点:

下面的代码片段为每个条设置了默认颜色('lightgrey')。单击一个条时,所有条都设置为其原始颜色,并且单击的条设置为“红色”。这种方法的好处是每个条形的起始颜色可以不同,并且会正确地切换到“红色”并返回。

let background = ['lightgrey', 'lightgrey', 'lightgrey', 'lightgrey'],
myChart = new Chart(document.getElementById('chart'), {
type: 'bar',
data: {
labels: ['a', 'b', 'c', 'd'],
datasets: [{
label: 'series1',
data: [7, 10, 8, 2],
backgroundColor: background.slice() // using .slice here 'clones' the array.
}]
},
options: {
maintainAspectRatio: false,
onClick: function(e, elems) {
if (elems.length) {
elems[0]._chart.config.data.datasets[0].data.forEach((value, index) => {

// set element to the original colour (resets all).
elems[0]._chart.config.data.datasets[0].backgroundColor[index] = background[index];
if (index == elems[0]._index) {
// set the clicked element to red.
elems[0]._chart.config.data.datasets[0].backgroundColor[index] = 'red';
}
});
myChart.update(); // if you don't want the animation use 'myChart.update(0);' instead.
}
}
}
});
<script type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/Chart.js/2.7.2/Chart.min.js"></script>
<canvas id="chart"></canvas>

注意事项:

  • 图例使用第一个点的颜色,因此当它被点击时图例颜色也会改变。
  • 这仅适用于第一个数据集 (elems[0]...datasets[0])。

关于javascript - 如何通过点击图表栏来改变颜色?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52544326/

26 4 0