首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何自定义Chart.js 2.0甜甜圈图的工具提示?

如何自定义Chart.js 2.0甜甜圈图的工具提示?
EN

Stack Overflow用户
提问于 2017-04-25 07:44:44
回答 6查看 138.2K关注 0票数 58

我试图用Chart.js2的甜甜圈图显示一些数据。

我目前的图表如下:

我想要的输出必须显示另一个属性,即百分比,如下所示:

我已经阅读了文档,但我无法处理这个问题,因为它非常通用,而且我对JavaScript还不熟悉。

我的第一个图表的代码如下:

代码语言: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'
        ]
      }]
    };
EN

回答 6

Stack Overflow用户

回答已采纳

发布于 2017-05-16 20:14:10

您可以使用图表选项工具提示配置部分自定义工具提示,如下所示:http://www.chartjs.org/docs/latest/configuration/tooltip.html#tooltip-configuration

如下面的示例代码所示,您可以更改颜色、大小和样式。查看上面链接的文档,以获得可配置选项的完整列表。

如果要将百分比添加到工具提示显示中,可以使用工具提示回调。文档包含所有可能的可自定义回调字段的列表。

在下面的示例中,我将"title“设置为”title“以显示标签名称,将" label”设置为显示值,并将百分比添加到"afterLabel“。

代码语言:javascript
复制
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/

票数 155
EN

Stack Overflow用户

发布于 2018-02-28 09:40:59

正如per @Tot的回答,但是为了简洁起见,使用箭头函数:

代码语言:javascript
复制
options: {
  tooltips: {
    callbacks: {
      title: (items, data) => data.datasets[items[0].datasetIndex].data[items[0].index].myProperty1,
      label: (item, data) => data.datasets[item.datasetIndex].data[item.index].myProperty2
    }
  }
}
票数 11
EN

Stack Overflow用户

发布于 2021-07-06 21:01:54

感谢图欣的回答。它帮助我弄清楚了如何使用回调函数更改工具提示标题。

我对javascript非常陌生,所以在Chart.js 3.4.1文档中,我并不清楚如何使用工具提示对象。按照建议,通过使用console.log(tooltipItems),我能够获得所需的信息。

最后,我得到了一个配置对象,它在options.plugins中设置了以下回调。我希望将缩短的日期字符串显示为工具提示的标题。使用toDateString()可以做到这一点。

以下是我如何设置我的回调:

代码语言:javascript
复制
    options: {
      ...

      plugins: {
        tooltip: {
          callbacks: {
            title: tooltipItems => {
              title = tooltipItems[0].parsed.x
              if (title !== null) {
                console.dir(title)
                title = new Date(title).toDateString()
              }
              return title
            },
          },
        },
      },
    },
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/43604597

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档