如何使用ChartJS获取水平条?

7kqas0il  于 2023-03-02  发布在  Chart.js
关注(0)|答案(1)|浏览(124)

在官方的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:最小值/最大值,但不起作用)
谢谢!!!

wdebmtf2

wdebmtf21#

由于indexAxis: 'y'不适合您,因此在本例中您似乎使用的是chart.js的V2,需要将类型指定为'horizontalBar'而不是'bar'

相关问题