как показать нг-повтор в угловых - PullRequest
0 голосов
/ 22 октября 2018

У меня есть данные списка JSON из API, он вызывается как

$scope.link = globalVar.folderAPI+"/web/data.php";
$http.get($scope.link).then(function(response){
    $scope.listDataitem = response.data.respone;
})

Я хочу показать период данных для построения диаграммы ниже, которую я написал, но все еще не может появиться, как сделать данныеотобразить на графике, как я могу проанализировать данные для части сценария диаграммы

<script>
var ctx = document.getElementById("myChart");
var myChart = new Chart(ctx, {
    type: 'bar',
    data: {
        labels: [<div ng-repeat=" x in listDataitem "> {{ x.period }} </div>],
        datasets: [{
                data: [<div ng-repeat="y in listDataitem"> {{ y.sales}} </div>],
                backgroundColor: [
                    'rgba(255, 99, 132, 0.2)',
                    'rgba(54, 162, 235, 0.2)',
                    'rgba(255, 206, 86, 0.2)',
                    'rgba(75, 192, 192, 0.2)',
                    'rgba(153,102,255,0.2)',
                    'rgba(255, 159, 64, 0.2)'
                ],
                borderColor: [
                    'rgba(255,99,132,1)',
                    'rgba(54, 162, 235, 1)',
                    'rgba(255, 206, 86, 1)',
                    'rgba(75, 192, 192, 1)',
                    'rgba(153, 102, 255, 1)',
                    'rgba(255, 159, 64, 1)'
                ],
                borderWidth: 1
            }]
    },
    options: {
        scales: {
            yAxes: [{
                    ticks: {
                        beginAtZero: true
                    }
                }]
        }
    }
});

1 Ответ

0 голосов
/ 22 октября 2018

Вы можете попробовать перерисовывать диаграмму каждый раз, когда будет вызываться ваш API.

$scope.link = globalVar.folderAPI+"/web/data.php";
$http.get($scope.link).then(function(response) {

    $scope.listDataitem = response.data.respone;

    let myLabels = [];
    let myDataset = [];

    for(let i = 0; i< $scope.listDitaitem); i++) {
        myLabels.push($scope.listDitaitem[i].period);
        myDataset.push($scope.listDitaitem[i].sales);
    }

    var ctx = document.getElementById("myChart");
    var myChart = new Chart(ctx, {
        type: 'bar',
        data: {
            labels: myLabels,
            datasets: [{
                data: myDataset,
                backgroundColor: [
                    'rgba(255, 99, 132, 0.2)',
                    'rgba(54, 162, 235, 0.2)',
                    'rgba(255, 206, 86, 0.2)',
                    'rgba(75, 192, 192, 0.2)',
                    'rgba(153,102,255,0.2)',
                    'rgba(255, 159, 64, 0.2)'
                ],
                borderColor: [
                    'rgba(255,99,132,1)',
                    'rgba(54, 162, 235, 1)',
                    'rgba(255, 206, 86, 1)',
                    'rgba(75, 192, 192, 1)',
                    'rgba(153, 102, 255, 1)',
                    'rgba(255, 159, 64, 1)'
                ],
                borderWidth: 1
            }]
        },
        options: {
            scales: {
                yAxes: [{
                    ticks: {
                        beginAtZero: true
                    }
                }]
            }
        }
    }); 
})
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...