我正在尝试使用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();
}
})();
答案 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语法,但两者都应该有效