Angular JS视图没有更新

时间:2017-02-08 14:20:23

标签: javascript angularjs json

我正在尝试使用promises和angularJS。

我的后端正在返回正确的值,但是我的html视图没有显示我的表,其中包含从后端返回的数据。

这里有什么问题?

这是我的HTML:

<div ng-app="clinang" ng-controller="pacientesCtrl">
     <a class='btn btnprimary' href='/getdadospac/?oper=S' >Button</a> 
     <table ng-table="tableParams" class="table" show-filter="true">
        <tr ng-repeat="paciente in $data">
            <td title="'Pront'" filter="{ name: 'text'}" sortable="'pront'">
                {{paciente.pront}}</td>
            <td title="'Nome'" filter="{ age: 'number'}" sortable="'nome'">
                {{paciente.nome}}</td>
        </tr>
    </table>
 </div>

这是我从后端返回的JSON数据:

{"draw":1,"recordsTotal":5303,"recordsFiltered":5303,
"data":[{"DT_RowId":"4367","pront":"4367","nome":"XXXXXXXXX","endereco":"RUA TEODORO DA SILVA,294\/314","bairro":"VILA ISABEL","cidade":"RIO DE JANEIRO","estado":"RJ","telefone":"2567*0440","cpf":"","email":""},
{"DT_RowId":"21","pront":"21","nome":"YYYYYYYYY","endereco":"R ARAGUAIA","bairro":"PARQUE CHUNO","cidade":"DUQUE DE CAXIAS","estado":"RJ","telefone":"35637685","cpf":"02570293709","email":"jaceni@ig.com.br"},
{"DT_RowId":"23","pront":"23","nome":"ZZZZZZZZZZ","endereco":"rua 18 de outubro 241 101","bairro":"tijuca","cidade":"RIO DE JANEIRO","estado":"RJ","telefone":"","cpf":"","email":""},
{"DT_RowId":"24","pront":"24","nome":"AAAAAAAAAAA","endereco":"RUA MARIZ E BARROS 470 APTO 610","bairro":"TIJUCA","cidade":"RIO DE JANEIRO","estado":"RJ","telefone":"22646701","cpf":"53551192715","email":""},
{"DT_RowId":"27","pront":"27","nome":"AAAAAAAA GON\u00C7ALVES","endereco":"rua an\u00E1polis 251","bairro":"nova igua\u00E7u","cidade":"RIO DE JANEIRO","estado":"RJ","telefone":"3101-9648","cpf":"","email":""},
{"DT_RowId":"28","pront":"28","nome":"ASKLJALDJSLKADJ","endereco":"lucio de mendon\u00E7a 24 apt 501","bairro":"maracana","cidade":"RIO DE JANEIRO","estado":"RJ","telefone":"2568-9519","cpf":"04301072772","email":""},
{"DT_RowId":"30","pront":"30","nome":"SADFSADFASDFSD","endereco":"RUA GRAVATAI N 61 APTO 302","bairro":"ROCHA MIRANDA","cidade":"RIO DE JANEIRO","estado":"RJ","telefone":"32787747","cpf":"","email":""},
{"DT_RowId":"29","pront":"29","nome":"ANASADFSA DOS SANTOS","endereco":"saboia lima 12 apt 04","bairro":"tijuca","cidade":"RIO DE JANEIRO","estado":"RJ","telefone":"2204-1498","cpf":"48080152268","email":""},
{"DT_RowId":"31","pront":"31","nome":"JOAO SDAFSA SOUZA","endereco":"av dom helder camara 312 bl 05 apt 102","bairro":"benfica","cidade":"RIO DE JANEIRO","estado":"RJ","telefone":"","cpf":"075422437-64","email":""},
{"DT_RowId":"33","pront":"33","nome":"SKDJFSDAJFLASD","endereco":"fabio da luz 275 bl 04 apt 504","bairro":"meier","cidade":"RIO DE JANEIRO","estado":"RJ","telefone":"3979-0859","cpf":"","email":""}]}

JS CODE:

var app = angular.module("clinang", ["ngTable", "ngResource"]);
            (function() {

              app.controller("pacientesCtrl", pacientesCtrl);
              pacientesCtrl.$inject = ["NgTableParams", "$resource"];

              function pacientesCtrl(NgTableParams, $resource) {
                // tip: to debug, open chrome dev tools and uncomment the following line 
                debugger;

                var Api = $resource("/getdadospac/?oper=S");
                this.tableParams = new NgTableParams({}, {
                  getData: function(params) {
                    // ajax request to api
                    return Api.get(params.url())
                      .$promise
                      .then(function(rows) {
                          params.total(rows.recordsTotal); // recal. page nav controls
                          return rows.data;
                    });
                  }
                });
                 this.tableParams.reload();
              }
            })();

2 个答案:

答案 0 :(得分:5)

你有控制器,调用和一切,但你需要使用范围将控制器的变量绑定到视图

    function pacientesCtrl(NgTableParams, $resource) {
      vm = this;
      vm.rows = []

      ..
      .then(function(rows) {
        vm.rows = rows.data;
       }

然后在你的HTML中:

    <tr ng-repeat="paciente in pacientesCtrl.rows">

你应该读一本书来学习角度,现在你已经玩了足够长的时间。它将强化一些概念,并有助于成长为开发者。我和你做了同样的事情,双手握住角度,打了太多墙壁,然后我读了一本书,一切都改变了

我还推荐这个简单有趣的课程:https://www.codeschool.com/courses/shaping-up-with-angular-js

答案 1 :(得分:1)

我认为您需要使用ControllerAs语法或使用$ scope。

ControllerAs: 由于您在控制器实例上设置了tableParams,因此您需要使用ControllerAs语法为控制器分配别名并访问该属性:

ng-controller="pacientesCtrl as ctrl"以及ng-table="ctrl.tableParams"

$范围

如果你想使用$ scope,那么你需要将$ scope注入你的控制器并将tableParams属性设置为$ scope,如:

var app = angular.module("clinang", ["ngTable", "ngResource"]);
        (function() {

          app.controller("pacientesCtrl", pacientesCtrl);
          pacientesCtrl.$inject = ["NgTableParams", "$resource", "$scope"];

          function pacientesCtrl(NgTableParams, $resource, $scope) {
            // tip: to debug, open chrome dev tools and uncomment the following line 
            debugger;

            var Api = $resource("/getdadospac/?oper=S");
            $scope.tableParams = new NgTableParams({}, {
              getData: function(params) {
                // ajax request to api
                return Api.get(params.url())
                  .$promise
                  .then(function(rows) {
                      params.total(rows.recordsTotal); // recal. page nav controls
                      return rows.data;
                });
              }
            });
            $scope.tableParams.reload();
          }
        })();

请注意,我们在tableParams上设置了$scope属性,而不是在控制器实例上。您的HTML应保持不变。

我个人更喜欢ControllerAs语法,但两者都应该有效