表格中的Chart.js饼图显示了页面调整大小时的怪异行为

时间:2019-01-18 07:26:20

标签: html-table chart.js

html表中有chart.js饼图。 问题是:先缩小然后再放大,单元格不会调整为初始大小。 布局看起来像这样:

 __________________________
|   inner div | inner div  |
|_____________|____________|
|             |            |
|  Pie1       |  Pie2      |
|_____________|____________|

我已经参考了documentation的大小调整和此link来在options对象中添加response和maintainAspectRatio字段。
设置active:true时,将启用该图以缩放。
设置maintainAspectRatio:false,可解决以前的不规则缩放问题,即多个图表由于采用表格单元格的宽度而无法按比例调整大小。
仅供参考,其中提到了chart.js zoom的模糊文本问题 github here

JS小提琴上的发行源代码:http://jsfiddle.net/rfaLvuho/
使用放大和缩小来重现。

1 个答案:

答案 0 :(得分:0)

您可以切换到<div>个元素来解决此布局。我在下面的代码段中使用了float,但它也应该与flexgrid布局一起使用。

var randomScalingFactor = function() {
  return Math.round(Math.random() * 100);
};

chartColors = {
  red: 'rgb(255, 99, 132)',
  orange: 'rgb(255, 159, 64)',
  yellow: 'rgb(255, 205, 86)',
  green: 'rgb(75, 192, 192)',
  blue: 'rgb(54, 162, 235)',
  purple: 'rgb(153, 102, 255)',
  grey: 'rgb(201, 203, 207)'
};
var config = {
  type: 'pie',
  data: {
    datasets: [{
      data: [
        randomScalingFactor(),
        randomScalingFactor(),
        randomScalingFactor(),
        randomScalingFactor(),
        randomScalingFactor(),
      ],
      backgroundColor: [
        chartColors.red,
        chartColors.orange,
        chartColors.yellow,
        chartColors.green,
        chartColors.blue,
      ],
      label: 'Dataset 1'
    }],
    labels: [
      'Red',
      'Orange',
      'Yellow',
      'Green',
      'Blue'
    ]
  },
  options: {
    responsive: true,
    maintainAspectRatio: false,
    legend: false
  }
};

var myPie1 = new Chart('chart-area1', config);
var myPie2 = new Chart('chart-area2', config);
.canvas-holder {
  width: 50%;
  float: left;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/Chart.js/2.7.3/Chart.min.js"></script>
<div class="canvas-holder">
  <canvas id="chart-area1"></canvas>
</div>
<div class="canvas-holder">
  <canvas id="chart-area2"></canvas>
</div>