将百分比值添加到图例标签的最简单方法是什么?
我相信它将使用generateLabels:函数(图表){},有人可以提供一个清晰的示例吗?
答案 0 :(得分:1)
如果您已经有一个图例数组,则可以使用此代码在其中添加百分比。 i 是数组中当前元素的索引。
data=[2,4,5,7];
legend=['A','B','C','D']
total = data.reduce((accumulator, currentValue) => parseInt(accumulator) + parseInt(currentValue));
labelsvalues = data.map(function(value,i){
let p= Math.round((value / total) * 100) + '%';
return legend[i]+' '+p;
});
答案 1 :(得分:0)
似乎没有任何本地方法可以显示百分比,但是计算并设置为标签非常简单:
const data = [1, 2, 3],
// ref: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/Reduce
total = data.reduce((accumulator, currentValue) => accumulator + currentValue),
// ref: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/map
labels = data.map(value => Math.round((value / total) * 100) + '%');
new Chart(document.getElementById('chart'), {
type: 'doughnut',
data: {
labels: labels,
datasets: [{
data: data
}]
}
});
<script src="https://cdnjs.cloudflare.com/ajax/libs/Chart.js/2.9.3/Chart.min.js"></script>
<canvas id="chart" height="75"></canvas>
(注意:使用Math.round()
可能导致某些数字集的总和不等于100%。)