图表 JS:旧图表数据未清除

Chart JS: Old chart data not clearing

我正在尝试完全更新 Chart JS 数据,但 x 轴上的旧数据标签没有重置。我的代码有什么问题吗?

    let netProfitData = @this.netProfitData;
    netProfitChart.data.datasets[0].data = netProfitData;

    console.log(netProfitChart.data.datasets);

    netProfitChart.data.datasets[0].backgroundColor = netProfitData.map((value) => 
    value.y > 0 ? fullConfig.theme.colors.green[400] : fullConfig.theme.colors.red[400]);

    netProfitChart.update();

数据集中的数据数组对我来说似乎是正确的。

这是因为内部 chart.js 仍然填充标签数组,因此您需要在替换数据之前清除该数组:

chart.data.labels = [];
chart.data.datasets[0].data = newData;
chart.update();

const options = {
  type: 'line',
  data: {
    datasets: [{
      label: '# of Votes',
      data: [{
        x: 'hi',
        y: 5
      }, {
        x: 'test',
        y: 10
      }, {
        x: 'end',
        y: 2
      }],
      borderColor: 'pink'
    }]
  },
  options: {}
}

const ctx = document.getElementById('chartJSContainer').getContext('2d');
const chart = new Chart(ctx, options);

chart.data.labels = [];
chart.data.datasets[0].data = [{
  x: 'k',
  y: 1
}, {
  x: 't',
  y: 4
}, {
  x: 'a',
  y: 5
}];
chart.update();
<body>
  <canvas id="chartJSContainer" width="600" height="400"></canvas>
  <script src="https://cdnjs.cloudflare.com/ajax/libs/Chart.js/3.6.0/chart.js"></script>
</body>