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/。
使用放大和缩小来重现。
答案 0 :(得分:0)
您可以切换到<div>
个元素来解决此布局。我在下面的代码段中使用了float
,但它也应该与flex
或grid
布局一起使用。
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>