我目前有一个3个标签页。每个选项卡都是一个div,未选中时设置为display: hidden
。在这些选项卡中,我有一个使用Susy(罗盘插件)创建的网格系统。每个标签页还有一组Highcharts。当我加载页面时,根据URl中的哪个选项卡,加载其中一个选项卡。所有的图表看起来都很好,但是当我切换到另一个标签时,一些图表在他们的div中不正确。如果我只是重新调整窗口大小,则会重新计算图表,然后它们完全匹配。或者,如果我重新加载相同的选项卡,图表也适合。 我可以调用一个功能,当我进行标签切换时会调整页面上所有图表的大小吗?
看起来像这样:
它应该是这样的:
编辑: 似乎这不是与highcharts直接相关的问题,例如我的谷歌地图如下所示:
但是当我调整窗口大小时,它会正确调整:
当切换选项卡时,我可以通过JS中的函数调用来刷新/调整网格吗?
答案 0 :(得分:46)
对我有用的是:
$(window).resize();
加载新标签页时。仍然存在Google Maps API的问题,但它适用于Highcharts。
答案 1 :(得分:6)
当您尝试使用" display:none"开始渲染时,您会发现很多问题。虽然$(window).resize()可能在很多情况下都有效,但我建议在显示之前先尝试渲染页面:none生效。一种可能的解决方案是设置不透明度:0或可见性:隐藏。
display属性控制元素的呈现方式,例如块(100%宽度)或内联(适合内容)。当一个元素有display:none时,它会覆盖它,最终删除它的有效宽度和高度,直到该元素收到一个块类型。
以下示例说明:http://jsfiddle.net/m2f3scmm/3/
<div id="log1" style="display: none;">
</div>
<div id="log2" style="visibility: hidden;">
</div>
<div id="log3" style="opacity: 0">
</div>
当您使用&#34;调整大小&#34; hack,你假设你正在使用的插件或脚本绑定到窗口的resize事件,但并非总是如此。触发window.resize也可能减慢渲染速度或导致不必要的效果(例如,小动画高级图表在第一次渲染时会发生 - 每次更改标签时都会发生蹩脚)。
答案 2 :(得分:3)
/**
* Adjust size for hidden charts
* @param chart highcharts
*/
function adjustGraph(chart) {
try {
if (typeof (chart === 'undefined' || chart === null) && this instanceof jQuery) { // if no obj chart and the context is set
this.find('.chart-container:visible').each(function () { // for only visible charts container in the curent context
$container = $(this); // context container
$container.find('div[id^="chart-"]').each(function () { // for only chart
$chart = $(this).highcharts(); // cast from JQuery to highcharts obj
$chart.setSize($container.width(), $chart.chartHeight, doAnimation = true); // adjust chart size with animation transition
});
});
} else {
chart.setSize($('.chart-container:visible').width(), chart.chartHeight, doAnimation = true); // if chart is set, adjust
}
}
catch (err) {
// do nothing
}
}
$(window).resize(function () {
if (this.resizeTO) clearTimeout(this.resizeTO);
this.resizeTO = setTimeout(function () {
// resizeEnd call function with pass context body
adjustGraph.call($('body'));
}, 500);
});
用于引导标签
$('a[data-toggle="tab"]').on('shown.bs.tab', function (e) {
var isChart = $(this).attr('data-chart');
var target = $(this).attr('href');
if (isChart) {
// call functio inside context target
adjustGraph.call($(target));
}
});
<ul id="tabs" class="nav nav-tabs" data-tabs="tabs">
<li class="active">
<a href="#anagrafica" data-toggle="tab"><h5>Anagrafica</h5></a>
</li>
<li>
<a href="#consumi" data-toggle="tab" data-chart="1"><h5>Consumi</h5></a>
</li>
</ul>
图表
new Highcharts.Chart({
chart: {
renderTo: 'chart-bar',
defaultSeriesType: 'column',
zoomType: 'xy',
backgroundColor: null,
events: {
load: function (event) {
adjustGraph(this);
}
}
},
html代码
div class="tab-pane" id="charts">
<div class="row-fluid">
<div class="span6 offset3">
<div id="myCarousel" class="carousel slide">
<!-- Carousel items -->
<div class="carousel-inner chart-container">
<div class="active item">
<h3>Chart 1/h3>
<div id="bar-pod-annuale">
<div id="chart-bar" style="width:100%;margin: 0 auto"></div>
</div>
</div>
<div class="item">
<h3>Char 2</h3>
/** chart **/
</div>
<div class="item">
<h3>Char 3</h3>
/** chart **/
</div>
</div>
<!-- Carousel nav -->
<a class="carousel-control left" href="#myCarousel" data-slide="prev">‹</a>
<a class="carousel-control right" href="#myCarousel" data-slide="next">›</a>
</div>
</div>
</div>
请参阅jsfiddle http://jsfiddle.net/davide_vallicella/LuxFd/2/