Графики Highcharts не изменяются правильно при изменении размера окна

У меня есть две бок о бок диаграммы на моей странице и хотели бы, чтобы они изменялись при изменении размера окна: их контейнер установлен на 50% ширины, что, согласно примерам, должно быть достаточно.

Можно найти рабочий пример автоматической диаграммы изменения размера @http://jsfiddle.net/2gtpA/

Нерабочий пример, который я сделал для воспроизведения проблемы, можно увидеть @http://jsfiddle.net/4rrZw/2/

ПРИМЕЧАНИЕ: вам нужно несколько раз изменить размер кадра, чтобы воспроизвести проблему (меньше > больше > меньше).

Я думаю, все это лежит в том, как вы объявляете контейнеры... вставка кода HTML в качестве кода JS для графических карт, по-видимому, не имеет здесь значения... (то же самое в обоих примерах)

<table style="width:100%;">
  <tr>
    <td style="width:50%;">
        <div id="container" style="height: 50%"></div>
    </td>
    <td style="width:50%;"></td>
  </tr>
</table>

Ответы

Ответ 1

Я развернул вашу скрипту к рабочему решению @http://jsfiddle.net/AxyNp/ Самый важный фрагмент кода отсюда:

$(window).resize(function() {
    height = chart.height
    width = $("#chartRow").width() / 2
    chart.setSize(width, height, doAnimation = true);
});

Решение встречается на этом в сообщении SO.

Похоже, что лучше всего изменить размер контейнера (и ячейки) диаграммы, чтобы полагаться на свой собственный триггер изменения размера. Обратите внимание, что я установил reflow в "false" в параметрах диаграммы, чтобы удалить существующий триггер.

Ответ 2

Вы можете избежать использования javascript для выполнения изменения размера и полагаться на css вместо этого. Это может быть достигнуто путем рендеринга HighChart в div, который имеет:

position: absolute;
width: 100%;

Чтобы убедиться, что высота контейнера уместна, вам придется обернуть этот абсолютно позиционированный элемент в другой элемент, который явно задал высоту:

position: relative;
width: 100%;
height: 400px;

Предоставляя HighChart в абсолютный элемент позиции, диаграмма будет реагировать на уменьшение ширины в родительском.

Ответ 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) {
    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>
</div> 

См. пример в jsfiddle

http://jsfiddle.net/davide_vallicella/LuxFd/2/