1. ホーム
  2. javascript

[解決済み] Chart.js 2.0 Doughnut Chartのツールチップをカスタマイズする方法は?

2022-02-12 14:19:24

質問

Chart.js2のドーナツチャートを使って、データを表示しようとしています。

現在のチャートは以下のような感じです。

私が望む出力は、別の属性、つまりパーセンテージを表示する必要があり、次のようになります。

ドキュメントを読みましたが、非常に一般的で、JavaScriptを初めて使うので、対処できません。

私の最初のチャートのコードは以下の通りです。

const renderCashCurrencyPie = (cashAnalysisBalances) => {
  if (cashAnalysisBalances) {
    const currenciesName = cashAnalysisBalances
    .map(curName => curName.currency);

    const availableCash = cashAnalysisBalances
    .map(avCash => avCash.availableCash);

    let currenciesCounter = 0;
    for (let i = 0; i < currenciesName.length; i += 1) {
      if (currenciesName[i] !== currenciesName[i + 1]) {
        currenciesCounter += 1;
      }
    }

    const currenciesData = {
      labels: currenciesName,
      datasets: [{
        data: availableCash,
        backgroundColor: [
          '#129CFF',
          '#0C6DB3',
          '#FF6384',
          '#00FFFF'
        ],
        hoverBackgroundColor: [
          '#FF6384',
          '#36A2EB',
          '#FFCE56',
          '#00FFFF'
        ]
      }]
    };

解決方法は?

ツールチップのカスタマイズは、チャートオプションのツールチップの設定セクションを使用して行うことができます。 http://www.chartjs.org/docs/latest/configuration/tooltip.html#tooltip-configuration

以下のコード例に示すように、色、サイズ、スタイルなどを変更することができます。設定可能なオプションの完全なリストについては、上記のリンク先のドキュメントを確認してください。

ツールチップの表示にパーセンテージを追加したい場合は ツールチップコールバック . ドキュメントに、カスタマイズ可能なすべてのコールバック・フィールドのリストがあります。

下の例では、ラベル名を表示するために "title"、値を表示するために "label"、そして "afterLabel" にパーセントを追加するように設定しています。

var myChart = new Chart(ctx, {
  type: 'doughnut',
  data: data,
  options: {
    tooltips: {
      callbacks: {
        title: function(tooltipItem, data) {
          return data['labels'][tooltipItem[0]['index']];
        },
        label: function(tooltipItem, data) {
          return data['datasets'][0]['data'][tooltipItem['index']];
        },
        afterLabel: function(tooltipItem, data) {
          var dataset = data['datasets'][0];
          var percent = Math.round((dataset['data'][tooltipItem['index']] / dataset["_meta"][0]['total']) * 100)
          return '(' + percent + '%)';
        }
      },
      backgroundColor: '#FFF',
      titleFontSize: 16,
      titleFontColor: '#0066ff',
      bodyFontColor: '#000',
      bodyFontSize: 14,
      displayColors: false
    }
  }
});

動くJSFiddle。 https://jsfiddle.net/m7s43hrs/