Взаимодействие с ChartJS от Flask - PullRequest
1 голос
/ 01 мая 2019

Я действительно запутался в том, что делать здесь. У меня есть скрипт на python, который делает некоторые классные вещи, а затем должен отображать эти классные вещи через некоторые графики.

Я видел, как это делается через Flask и ChartJS, но каждый сайт, который я видел, использует его для отображения статического контента, что, конечно, не то, что мне нужно.

Я пытался сделать это с этим шаблоном:

<!doctype html>
<html>

<head>
    <title>Line Chart</title>
    <script src="/static/chartjs/Chart.min.js"></script>
    <script src="/static/chartjs/utils.js"></script>
    <style>
    canvas{
        -moz-user-select: none;
        -webkit-user-select: none;
        -ms-user-select: none;
    }
    </style>
</head>

<body>
    <div style="width:75%;">
        <canvas id="canvas"></canvas>
    </div>
    <br>
    <br>
    <button id="randomizeData">Randomize Data</button>
    <button id="addDataset">Add Dataset</button>
    <button id="removeDataset">Remove Dataset</button>
    <button id="addData">Add Data</button>
    <button id="removeData">Remove Data</button>
    <script>
        var MONTHS =  [];
        var config = {
            type: 'line',
            data: {
                labels: ['1/05/19\n00:57', '1/05/19\n00:58', '1/05/19\n00:59', '1/05/19\n01:00', '1/05/19\n01:01', '1/05/19\n01:02', '1/05/19\n01:03'],

                {{ dataset }}

            },
            options: {
                responsive: true,
                title: {
                    display: true,
                    text: 'Chart.js Line Chart'
                },
                tooltips: {
                    mode: 'index',
                    intersect: false,
                },
                hover: {
                    mode: 'nearest',
                    intersect: true
                },
                scales: {
                    xAxes: [{
                        display: true,
                        scaleLabel: {
                            display: true,
                            labelString: 'Month'
                        }
                    }],
                    yAxes: [{
                        display: true,
                        scaleLabel: {
                            display: true,
                            labelString: 'Value'
                        }
                    }]
                }
            }
        };

        window.onload = function() {
            var ctx = document.getElementById('canvas').getContext('2d');
            window.myLine = new Chart(ctx, config);
        };

        document.getElementById('randomizeData').addEventListener('click', function() {
            config.data.datasets.forEach(function(dataset) {
                dataset.data = dataset.data.map(function() {
                    return randomScalingFactor();
                });

            });

            window.myLine.update();
        });

        var colorNames = Object.keys(window.chartColors);
        document.getElementById('addDataset').addEventListener('click', function() {
            var colorName = colorNames[config.data.datasets.length % colorNames.length];
            var newColor = window.chartColors[colorName];
            var newDataset = {
                label: 'Dataset ' + config.data.datasets.length,
                backgroundColor: newColor,
                borderColor: newColor,
                data: [],
                fill: false
            };

            for (var index = 0; index < config.data.labels.length; ++index) {
                newDataset.data.push(randomScalingFactor());
            }

            config.data.datasets.push(newDataset);
            window.myLine.update();
        });

        document.getElementById('addData').addEventListener('click', function() {
            if (config.data.datasets.length > 0) {
                var month = MONTHS[1];
                config.data.labels.push(month);

                config.data.datasets.forEach(function(dataset) {
                    dataset.data.push(randomScalingFactor());
                });

                window.myLine.update();
            }
        });

        document.getElementById('removeDataset').addEventListener('click', function() {
            config.data.datasets.splice(0, 1);
            window.myLine.update();
        });

        document.getElementById('removeData').addEventListener('click', function() {
            config.data.labels.splice(-1, 1); // remove the label first

            config.data.datasets.forEach(function(dataset) {
                dataset.data.pop();
            });

            window.myLine.update();
        });
    </script>
</body>

</html>

Это содержит много неиспользованного материала (он был загружен непосредственно из примеров chart.js) и немного изменен мной (см. {{ dataset }})

И это код Python, который я использую для генерации dataset части:

def generate_dataset(self):
    data = 'datasets: ['

    for post_list_index, post in enumerate(self.post_list):
        data =  data + "{label: '" + post + "', backgroundColor: window.chartColors.red, borderColor: window.chartColors.red, data: ["
        for index, history in enumerate(self.submissions_score_history):
            score = history[post_list_index]
            if index < len(self.submissions_score_history) - 1:
                data = data + str(score) + ','
            else:
                data = data + str(score)
        data = data + '],fill: false,}'

        if post_list_index < len(self.post_list) - 1:
            data = data + ','
        else:
            pass
    data = data + ']'
    return data

Теперь, к сожалению, это ничего не делает. Я почти уверен, что это из-за того, что label: 'label'; сбежал на &#39label&#39;.

Я искал эту проблему, и, по-видимому, эта попытка внедрения javascript, которую я пытаюсь сделать, была удалена, поскольку она представляет уязвимость безопасности.

Этот проект в буквальном смысле слова - всего лишь инструментальная панель для другого небольшого проекта на Python, который будет использоваться только мной, поэтому я пытался создать что-то быстро и легко, но это оказалось довольно проблематичным: /

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...