Chart.js:饼图的宽度和高度未得到遵守

时间:2018-03-26 10:25:24

标签: javascript html css chart.js

我使用Chart.js创建饼图。我需要每张图表为76x76px。不幸的是,渲染图表总是比包装div和画布本身的尺寸小一点。

如果你在 FIDDLE 中检查图表,你就会明白我的意思:canvas元素的大小是固定的,但图表本身并没有&# 39;完全填充它。

enter image description here

这几乎就像是为那些不存在的东西保留了一个上边距。

代码:

HTML

<div class="wrapper">
  <canvas id="myChart" width="76" height="76"></canvas>
</div>

JS

var ctx = document.getElementById("myChart").getContext('2d');
var myChart = new Chart(ctx, {
    type: 'pie',
    data: {
        datasets: [{
            data: [30, 70],
            backgroundColor: [
                'green',
                'gray'
            ],
            borderWidth: 0
        }]
    },
    options: {
        tooltips: {
             enabled: false
        },
        events: []
    }
});

CSS

.wrapper {
  width: 76px;
  height: 76px;
}

我应该怎样做才能让饼图填满76x76px画布?

1 个答案:

答案 0 :(得分:5)

legend保留了额外空间,默认情况下已启用。只需禁用它,您就应该拥有图表的整个空间:

legend: {
  display: false
}

一个工作示例:

&#13;
&#13;
var ctx = document.getElementById("myChart").getContext('2d');
var myChart = new Chart(ctx, {
  type: 'pie',
  data: {
    datasets: [{
      data: [30, 70],
      backgroundColor: [
        'green',
        'gray'
      ],
      borderWidth: 0
    }]
  },
  options: {
    tooltips: {
      enabled: false
    },
    legend: {
      display: false  // <- the important part
    },
    events: []
  }
});
&#13;
.wrapper {
  width: 76px;
  height: 76px;
  border: 1px solid black; /* for demonstration purposes*/
}
&#13;
<script src="https://cdnjs.cloudflare.com/ajax/libs/Chart.js/2.7.2/Chart.min.js"></script>
<div class="wrapper">
  <canvas id="myChart" width="76" height="76"></canvas>
</div>
&#13;
&#13;
&#13;