如何在chartjs中排序,插入之间和更新完整数据集?

Arc*_*hne 3 chart.js

我有一些Chartjs问题,简单的更新方法无法解决。

我想知道是否可以选择:

  1. 轻松地对数据集进行排序;
  2. 在两点之间插入一些数据;
  3. 重新加载整个图表,而不用全新的图表替换画布?

pot*_*ngs 5

没有内置的选择,但它是很容易编写自己的使用addDataremoveData方法是chart.js之规定。

var MyBarChartMethods = {
    // sort a dataset
    sort: function (chart, datasetIndex) {
        var data = []
        chart.datasets.forEach(function (dataset, i) {
            dataset.bars.forEach(function (bar, j) {
                if (i === 0) {
                    data.push({
                        label: chart.scale.xLabels[j],
                        values: [bar.value]
                    })
                } else 
                    data[j].values.push(bar.value)
            });
        })

        data.sort(function (a, b) {
            if (a.values[datasetIndex] > b.values[datasetIndex])
                return -1;
            else if (a.values[datasetIndex] < b.values[datasetIndex])
                return 1;
            else
                return 0;
        })

        chart.datasets.forEach(function (dataset, i) {
            dataset.bars.forEach(function (bar, j) {
                if (i === 0)
                    chart.scale.xLabels[j] = data[j].label;
                bar.label = data[j].label;
                bar.value = data[j].values[i];
            })
        });
        chart.update();
    },
    // reload data
    reload: function (chart, datasetIndex, labels, values) {
        var diff = chart.datasets[datasetIndex].bars.length - values.length;
        if (diff < 0) {
            for (var i = 0; i < -diff; i++)
                chart.addData([0], "");
        } else if (diff > 0) {
            for (var i = 0; i < diff; i++)
                chart.removeData();
        }

        chart.datasets[datasetIndex].bars.forEach(function (bar, i) {
            chart.scale.xLabels[i] = labels[i];
            bar.value = values[i];
        })
        chart.update();
    }
}
Run Code Online (Sandbox Code Playgroud)

您这样称呼(其中myBarChart是您的图表)

// sort
MyBarChartMethods.sort(myBarChart, 0)
// reload - same number of values
MyBarChartMethods.reload(myBarChart, 0, ["J", "F", "M", "A", "M", "J", "J"], [1, 2, 3, 4, 5, 6, 7])
// reload - more values
MyBarChartMethods.reload(myBarChart, 0, ["J", "F", "M", "A", "M", "J", "J", "A"], [1, 2, 3, 4, 5, 6, 7, 8])
// reload - less values
MyBarChartMethods.reload(myBarChart, 0, ["J", "F", "M", "A", "M"], [1, 2, 3, 4, 5])
Run Code Online (Sandbox Code Playgroud)

插入2点是重新加载的特殊情况,因此您可以使用相同的功能(或根据此功能轻松编写自己的功能)


小提琴-http: //jsfiddle.net/Lkdxxkfa/

  • @potatopeelings-我修改了您的小提琴:https://jsfiddle.net/yscmsa0r/1/仅将对一个数据集进行排序,而另一个数据集的条形不变。这没有任何意义,因为排序后,月份对于其他数据集将不再正确。 (2认同)
  • @Joko-谢谢队友!我已经更新了答案和小提琴-这是上述小提琴的修改版本-https://jsfiddle.net/jzezwu7u/ (2认同)