Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/jquery/80.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript 重新绘制相同的高度图_Javascript_Jquery_Highcharts_Redraw - Fatal编程技术网

Javascript 重新绘制相同的高度图

Javascript 重新绘制相同的高度图,javascript,jquery,highcharts,redraw,Javascript,Jquery,Highcharts,Redraw,我正在使用具有多个条形图的海图。。我想要的是在特定的按钮点击时复制图表的加载效果。。。我尝试了以下代码 $('#container').highcharts({ chart: { type: 'column' }, title: { text: 'Monthly Average Rainfall'

我正在使用具有多个条形图的海图。。我想要的是在特定的按钮点击时复制图表的加载效果。。。我尝试了以下代码

   $('#container').highcharts({
                chart: {
                    type: 'column'
                },
                title: {
                    text: 'Monthly Average Rainfall'
                },
                subtitle: {
                    text: 'Source: WorldClimate.com'
                },
                xAxis: {
                    categories: [
                        'Jan',
                        'Feb',
                        'Mar',
                        'Apr',
                        'May',
                        'Jun',
                        'Jul',
                        'Aug',
                        'Sep',
                        'Oct',
                        'Nov',
                        'Dec'
                    ],
                    crosshair: true
                },
                yAxis: {
                    min: 0,
                    title: {
                        text: 'Rainfall (mm)'
                    }
                },
                tooltip: {
                    headerFormat: '<span style="font-size:10px">{point.key}</span><table>',
                    pointFormat: '<tr><td style="color:{series.color};padding:0">{series.name}: </td>' +
                            '<td style="padding:0"><b>{point.y:.1f} mm</b></td></tr>',
                    footerFormat: '</table>',
                    shared: true,
                    useHTML: true
                },
                plotOptions: {
                    column: {
                        pointPadding: 0.2,
                        borderWidth: 0
                    }
                },
                series: [{
                        name: 'Tokyo',
                        data: [49.9, 71.5, 106.4, 129.2, 144.0, 176.0, 135.6, 148.5, 216.4, 194.1, 95.6, 54.4]

                    }, {
                        name: 'New York',
                        data: [83.6, 78.8, 98.5, 93.4, 106.0, 84.5, 105.0, 104.3, 91.2, 83.5, 106.6, 92.3]

                    }, {
                        name: 'London',
                        data: [48.9, 38.8, 39.3, 41.4, 47.0, 48.3, 59.0, 59.6, 52.4, 65.2, 59.3, 51.2]

                    }, {
                        name: 'Berlin',
                        data: [42.4, 33.2, 34.5, 39.7, 52.6, 75.5, 57.4, 60.4, 47.6, 39.1, 46.8, 51.1]

                    }]
            });


function redrawing()
        {


            $('#container').highcharts().redraw();
        }
$(“#容器”)。高图({
图表:{
类型:“列”
},
标题:{
文字:“月平均降雨量”
},
副标题:{
文本:'来源:WorldClimate.com'
},
xAxis:{
类别:[
“一月”,
二月,,
“三月”,
“四月”,
“五月”,
"六月",,
七月,,
"八月",,
"九月",,
“十月”,
十一月,,
“十二月”
],
十字准星:对
},
亚克斯:{
分:0,,
标题:{
文字:“降雨量(毫米)”
}
},
工具提示:{
headerFormat:“{point.key}”,
pointFormat:“{series.name}:”+
“{point.y:.1f}mm”,
页脚格式:“”,
分享:是的,
useHTML:true
},
打印选项:{
专栏:{
点填充:0.2,
边框宽度:0
}
},
系列:[{
名称:"东京",,
数据:[49.9,71.5,106.4129.2,144.0176.0,135.6148.51216.4194.1,95.6,54.4]
}, {
名称:'纽约',
数据:[83.6,78.8,98.5,93.4,106.0,84.5,105.0,104.3,91.2,83.5,106.6,92.3]
}, {
名称:“伦敦”,
数据:[48.9,38.8,39.3,41.4,47.0,48.3,59.0,59.6,52.4,65.2,59.3,51.2]
}, {
名称:“柏林”,
数据:[42.4,33.2,34.5,39.7,52.6,75.5,57.4,60.4,47.6,39.1,46.8,51.1]
}]
});
函数重画()
{
$(“#容器”).highcharts().redraw();
}

但这是行不通的。我不想更改图表中的任何数据或任何内容。我只想在我点击按钮时重新加载它。

建议的方法是销毁然后重新创建图表:

这是一把小提琴,显示了这一点:


我为您准备了一个演示,它允许“再次运行开始动画”和停止/暂停

var H = Highcharts,
    c = $('#container').highcharts(),
    chart = c;

H.Series.prototype.afterAnimate = function() {};

function reAnimate(fromStart) {
    // store animation:

    var seriesAnimate = H.Series.prototype.animate;
    var columnAnimate = H.seriesTypes.column.prototype.animate;
    var pieAnimate = H.seriesTypes.pie.prototype.animate;

    // run animation again: tested with line chart only
    H.each(c.series, function (s) {
        if (animation && !isObject(animation)) {
            animation = defaultPlotOptions[series.type].animation;
        }
        var animation = s.options.animation,
            clipBox = s.clipBox || c.clipBox,
            sharedClipKey = ['_sharedClip', animation.duration, animation.easing, clipBox.height].join(','),
            clipRect = c[sharedClipKey],
            markerClipRect = c[sharedClipKey + 'm'];

        if (fromStart) {
            if (clipRect) {
                clipRect.attr({
                    width: 0
                });
            }
            if (markerClipRect) {
                markerClipRect.attr({
                    width: 0
                });
            }
        }
        s.animate = s.type == 'pie' ? pieAnimate : (s.type == 'column' ? columnAnimate : seriesAnimate);
        //s.animate(true);
        s.animate();
    });
}

function isObject(obj) {
    return obj && typeof obj === 'object';
}
例如:

var H = Highcharts,
    c = $('#container').highcharts(),
    chart = c;

H.Series.prototype.afterAnimate = function() {};

function reAnimate(fromStart) {
    // store animation:

    var seriesAnimate = H.Series.prototype.animate;
    var columnAnimate = H.seriesTypes.column.prototype.animate;
    var pieAnimate = H.seriesTypes.pie.prototype.animate;

    // run animation again: tested with line chart only
    H.each(c.series, function (s) {
        if (animation && !isObject(animation)) {
            animation = defaultPlotOptions[series.type].animation;
        }
        var animation = s.options.animation,
            clipBox = s.clipBox || c.clipBox,
            sharedClipKey = ['_sharedClip', animation.duration, animation.easing, clipBox.height].join(','),
            clipRect = c[sharedClipKey],
            markerClipRect = c[sharedClipKey + 'm'];

        if (fromStart) {
            if (clipRect) {
                clipRect.attr({
                    width: 0
                });
            }
            if (markerClipRect) {
                markerClipRect.attr({
                    width: 0
                });
            }
        }
        s.animate = s.type == 'pie' ? pieAnimate : (s.type == 'column' ? columnAnimate : seriesAnimate);
        //s.animate(true);
        s.animate();
    });
}

function isObject(obj) {
    return obj && typeof obj === 'object';
}