php - highcharts 系列删除功能删除所有原始系列数据(即使存储在新变量中)

标签 php javascript reference highcharts

每当我在 highcharts 钻取函数中调用 series.remove() 时,图表系列就会按预期删除并取消设置。但是,我需要存储原始图表数据以便“钻取备份”。

我已将数据保存到另一个变量中,但调用删除也会取消设置我存储在该变量中的数据。我猜它是以某种方式通过引用存储的?

我尝试使用 jquery 函数复制数据,但数据仍然被 highcharts series.remove() 函数删除。

这是我的 onclick 代码:

function() {

    var drilldown = this.series.options.drilldownSeries;

    if (drilldown) {
        setChart(drilldown[this.category]);
    }
    else {
        setChart('drillUp');
    }
}

这是我的 setChart 代码:

window.rhChartDataBank = {};

function setChart(data) {

    if (data !== 'drillUp'){

        //HERE'S WHERE i TRY TO COPY THE DATA TO ANOTHER PLACE
        if (window.rhChartDataBank._originalData === undefined || window.rhChartDataBank._originalCategories === undefined){

            var series0 = jQuery.extend(true, {}, hChart.series[0].data),
            series1 = jQuery.extend(true, {}, hChart.series[1].data);

            window.rhChartDataBank._originalData = [];
            window.rhChartDataBank._originalCategories = [];

            window.rhChartDataBank._originalData.push(series0);
            window.rhChartDataBank._originalData.push(series1);
            window.rhChartDataBank._originalCategories = hChart.series[0].xAxis.categories;
        }

        //Remove current series
        while(hChart.series.length > 0){
            hChart.series[0].remove(false);
        }

        //Set new categories
        var newCategories = [];
        for (var i = 0; i < data.length; i++) {
            newCategories.push(data[i].data.x);
        }

        //Set new data
        var newData = [];
        for (var i = 0; i < data.length; i++) {
            newData.push(data[i].data.y);
        }

        hChart.xAxis[0].setCategories(newCategories, false);

        hChart.addSeries({
            type: 'column',  
            data: newData,
        }, false);

        hChart.redraw();
    }
    else{
        //Remove current series
        while(hChart.series.length > 0){
            hChart.series[0].remove(false);
        }

        //BY THE TIME THIS RUNS window.rhChartDataBank._originalData is full of only null values.

        //Set old categories
        var oldCategories = [];
        for (var i = 0; i < window.rhChartDataBank._originalCategories.length; i++) {
            oldCategories.push(window.rhChartDataBank._originalCategories[i]);
        }

        //Set old data
        var oldData = [];
        for (var i = 0; i < window.rhChartDataBank._originalData[0].length; i++) {
            oldData.push(window.rhChartDataBank._originalData[0][i]['y']);
        }

        hChart.xAxis[0].setCategories(window.rhChartDataBank._originalCategories, false);

        //ADDING IN DUMMY DATA FOR NOW SINCE I CAN'T GET DATA FROM ORIGINAL CHART...
        var ddddata = [45,20,70];

        hChart.addSeries({
            type: 'column',  
            data: ddddata,
        }, false);

        hChart.redraw();
    }
}

最佳答案

由于 hChart.series 是一个数组,因此您可以轻松地克隆该数组

var backup_series = hChart.series.slice(0);

这样您就可以在需要时恢复原始系列。

关于php - highcharts 系列删除功能删除所有原始系列数据(即使存储在新变量中),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18261698/

相关文章:

c++11 - 返回统一的初始化引用是否有效?

javascript - 未捕获的类型错误 : Cannot read property 'get' of undefined when detecting chrome extension

javascript - 如何使用 Action razor 语法在 ajax url 中使用 var

java - 有人可以解释在 String 类中被覆盖的 toString 方法的源代码吗?

php - 这是在两种不同类型的数组之间进行转换的最佳方法吗?

php - 获取单行致命 php 错误的完整堆栈跟踪

php - Codeigniter 从数据表日期时间格式中按天选择日期

php - "Mass Assignment"在 Laravel 中是什么意思?

javascript - 如何通过脚本将转换应用于 Illustrator 中的选区

swift : affect struct by reference or "alias" to a variable