【发布时间】:2018-08-27 17:09:46
【问题描述】:
我有一个带有四个标签的饼图:
var data = [{
data: [50, 55, 60, 33],
labels: ["India", "China", "US", "Canada"],
backgroundColor: [
"#4b77a9",
"#5f255f",
"#d21243",
"#B27200"
],
borderColor: "#fff"
}];
使用chartjs-plugin-datalabels 插件,我想用下面的代码在每个 Pie 中显示百分比值:
formatter: (value, ctx) => {
let datasets = ctx.chart.data.datasets;
if (datasets.indexOf(ctx.dataset) === datasets.length - 1) {
let sum = 0;
datasets.map(dataset => {
sum += dataset.data[ctx.dataIndex];
});
let percentage = Math.round((value / sum) * 100) + '%';
return percentage;
} else {
return percentage;
}
},
color: '#fff',
}
我得到所有馅饼的 100% 价值,而不是各自的百分比。 这是 JSFiddle (https://jsfiddle.net/kingBethal/a1Lvn4eb/7/)
【问题讨论】:
-
我知道
chartjs-plugin-labels可以实现这一点,但我更喜欢chartjs-plugin-datalabels,因为我依赖这个插件来实现其他图表功能。
标签: javascript charts chart.js