Получить данные Ajax в угловую сетку

20

Используя Angular Grid, я получаю данные ajax get в console.log. Но пустая сетка.

Журнал консоли читает:

[13:56:11.411] now!!
[13:56:11.412] []
[13:56:11.412] now!!
[13:56:11.556]  <there is data returned from console.log(getData); > 

Это файл js.

// main.js
var app = angular.module('myApp', ['ngGrid']);

var getData = [];

function fetchData() {
    var mydata = [];

    $.ajax({
        url:'/url/to/hell',
        type:'GET',
        success: function(data) {

            for(i = 0, j = data.length; i < j; i++) {
                mydata[i] = data[i];
            }
            getData = mydata;
            console.log(getData);
        }
    });    
 }
fetchData();     


app.controller('MyCtrl', function($scope) {    

    console.log('now!!')
    console.log(getData)
    console.log('now!!')

    $scope.myData = getData


    $scope.gridOptions = { 
        data: 'myData',
        showGroupPanel: true
    };
});

Новый файл Js:

//main.js

var app = angular.module('myApp', ['ngGrid']);

app.controller('MyCtrl', function($scope, $http) {          
function fetchData() {
    $http({
        url:'/url/to/hell',
        type:'GET'})
        .success(function(data) {
            $scope.myData = data;       
            $scope.gridOptions = { 
                    data: 'myData',
                    showGroupPanel: true
                };              
        });         
}   
fetchData();    
});

HTML файл.

<html ng-app="myApp">
        <head lang="en">
            <meta charset="utf-8">
            <title>Blank Title 3</title>  
            <link rel="stylesheet" type="text/css" href="http://angular-ui.github.com/ng-grid/css/ng-grid.css" />
            <link rel="stylesheet" type="text/css" href="../static/css/style.css" />
            <script src="https://ajax.googleapis.com/ajax/libs/jquery/1.8.0/jquery.min.js"></script>
            <script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.0.2/angular.min.js"></script>
            <script type="text/javascript" src="http://angular-ui.github.com/ng-grid/lib/ng-grid.debug.js"></script>
            <script type="text/javascript" src="../static/js/main.js"></script>
        </head>

        <body ng-controller="MyCtrl">

            <div class="gridStyle" ng-grid="gridOptions"></div>
        </body>
    </html>
Теги:
ng-grid

2 ответа

13
Лучший ответ

Ваш контроллер, вероятно, обращается к массиву getData до завершения .success. Вы получаете доступ к переменной сразу, вне функции обещания, которая инициализируется пустым массивом.

Почему бы вам не попробовать помещать функцию fetchData в контроллер (пока) и хранить getData непосредственно в $scope.myData в .success? Может быть, даже инициализировать сетку тоже? Не уверен, что вы можете это сделать, но если бы вы могли, это выглядело бы так:

app.controller('MyCtrl', function($scope, $http) {  
$scope.myData = '';
$scope.gridOptions = { showGroupPanel: true, data: 'myData' };
function fetchData() {
    setTimeout(function(){  
        $http({
            url:'/url/to/hell',
            type:'GET'})
            .success(function(data) {
                $scope.myData = data;   
                if (!$scope.$$phase) {
                    $scope.$apply();
                }                   
            });         
    }, 3000);       
}   
fetchData();    
});

(источник для некоторых приложений $scope применяется: https://github.com/angular-ui/ng-grid/issues/39)

Также не уверен, почему вы смешиваете jQuery.ajax с кодом angular (это будет $http), и почему ни один из ваших javascript не имеет точку с запятой.

  • 0
    Как определить $ http?
  • 0
    Извините, обновлен фрагмент кода. Вы просто вводите его так же, как $ scope. $ http - это основной угловой сервис. Если у вас есть RESTful API, вы также можете использовать $ resource для дальнейшей абстракции.
Показать ещё 7 комментариев
25

Это было бы намного проще (и более Angular), если вы определили сервис для своего запроса. Что-то в этом роде:

angular.module('hellServices', ['ngResource'])
  .factory('Hell', function ($resource) {
    return $resource('URL/TO/HELL', {}, {
      query: { method: 'GET' }
    });
  });

Обязательно включите его в свое приложение:

var app = angular.module('myApp', ['ngGrid', 'hellServices']);

Тогда вы можете получить обещание для этого в своем контроллере:

app.controller('MyCtrl', function($scope, $http, Hell) {  
$scope.myData = Hell.query();

И затем установите параметры сетки, чтобы посмотреть на обещание для своих данных (как вы уже сделали):

$scope.gridOptions = { 
    data: 'myData',
    showGroupPanel: true
};

Если вы это сделаете, вам не нужно беспокоиться о $scope. $apply, потому что он будет обработан для вас. Это намного чище и легче следовать. Если вам по-прежнему нужен обратный вызов для изменения данных после его возврата с сервера, передайте функцию функции query() вашей службы:

...
$scope.myData = Hell.query(function(hell) {
    // code that modifies 'hell'
});

Ознакомьтесь с официальными документами в службах Angular. Основы также описаны в Шаг № 11 официального учебника Angular JS.

Ещё вопросы

Сообщество Overcoder
Наверх
Меню