在官方的ChartJS文档中,我尝试为我的每个数据设置水平条。我尝试使用x或y,更改选项或数据集,但没有成功。我应该指出,没有其他JS或SCSS应用于此。如何设置水平条?非常感谢!
结果:
细枝
<canvas id="skills{{ i }}"> </canvas>
JS系统
var chartContainer2 = document.getElementById('skills0');
var ctxSkills = chartContainer2.getContext('2d');
const data = {
labels: ['a', 'b', 'c', 'd', 'e', 'f', 'g'],
datasets: [{
axis: 'y',
label: 'My First Dataset',
data: [65, 59, 80, 81, 56, 55, 40],
fill: false,
backgroundColor: [
'rgba(255, 99, 132, 0.2)',
'rgba(255, 159, 64, 0.2)',
'rgba(255, 205, 86, 0.2)',
'rgba(75, 192, 192, 0.2)',
'rgba(54, 162, 235, 0.2)',
'rgba(153, 102, 255, 0.2)',
'rgba(201, 203, 207, 0.2)'
],
borderColor: [
'rgb(255, 99, 132)',
'rgb(255, 159, 64)',
'rgb(255, 205, 86)',
'rgb(75, 192, 192)',
'rgb(54, 162, 235)',
'rgb(153, 102, 255)',
'rgb(201, 203, 207)'
],
borderWidth: 1
}]
};
var chartBar = new Chart(chartContainer2, {
type: 'bar',
data,
options: {
indexAxis: 'y',
scales: {
x: {
min: 0,
max: 100,
stacked: true
},
y: [{
stacked: true
}]
},
}
});
我还希望左边的数字从0到100(我尝试使用x:最小值/最大值,但不起作用)
谢谢!!!
1条答案
按热度按时间wdebmtf21#
由于
indexAxis: 'y'
不适合您,因此在本例中您似乎使用的是chart.js的V2,需要将类型指定为'horizontalBar'
而不是'bar'