javascript - AngularJS 服务获取数据,但不将其返回给 Controller ?

标签 javascript angularjs angularjs-service angular-promise

Controller 中的scope.membersWarnings始终为空,但在服务中它从服务器获取数据。不知何故,我来自服务器的数据在服务和 Controller 中的 get 函数的回调之间丢失了。

Controller :

AndreaApp.controller('MemberDetailController', ['$scope', '$rootScope','$http','$location','$routeParams','MemberService','MemberGroupsService','ArrivalsService','WarningsService','NotificationsService',function (scope,rootScope, http,location,routeParams,MemberService,MemberGroupsService,ArrivalsService,WarningsService,NotificationsService) { 

scope.member = MemberService.get(routeParams.id);
scope.membersGroup = MemberService.membersGroup(routeParams.id);
scope.membersWarnings = WarningsService.get(routeParams.id);

scope.editMember = function(id){
    location.path('/editMember/'+id);
}

scope.membersDocument = function(id){
    location.path('/membersDocument/'+id);
}

scope.templates =
[ { name: 'packages.html', url: 'views/members/packages.html'},
{ name: 'notifications.html', url: 'views/members/notifications.html'},
{ name: 'warnings.html', url: 'views/members/warnings.html'},
{ name: 'arrivals.html', url: 'views/members/arrivals.html'} ];

scope.template = scope.templates[0];
scope.loadTemplate = function(templateId){
    if(templateId == 3){
        scope.arrivals = ArrivalsService.get(routeParams.id).arrivalsId;
        console.log(scope.arrivals);
    }
    scope.template = scope.templates[templateId];
}}]);

警告服务:

AndreaApp.service('WarningsService', function ($http,$q) {
var warnings = [];
this.save = function (warnings, memberId) {

  $http.post('/api/warnings/new/member/'+memberId, 
  {
    name: warnings.name,
    description: warnings.description,
    readed: false,   
    clanId: memberId
  }).
  success(function(data, status, headers, config) {


  }).
  error(function(data, status, headers, config) {
        alert("Error occurred while adding a warning. HTTP Respone: " + status);    
  });


}

this.get = function (id) {
    var deferred = $q.defer();
    $http.get('/api/warnings/member/'+id).
      success(function(data, status, headers, config) {

              warnings.length = 0;
              console.log(data);
              for(var i = 0; i < data.length; i++){
                warnings.push(data[i]);

              }
              deferred.resolve(data);

              //data exists here, it is not empty
            }).
            error(function(data, status, headers, config) {

              alert("HTTP status:" + status)
            });
    return deferred;
}});

最佳答案

您可以只返回 $http,如下所示:

this.get = function (id) {
    return $http.get('/api/warnings/member/'+id);
}

然后你就可以在 Controller 上使用它了。

WarningsService.get(routeParams.id).then(function(result){
    $scope.membersWarnings = result.data; // or just result
});

你不能像你正在做的那样分配,因为你以这种方式返回一个 promise 。此时结果尚未准备就绪

关于javascript - AngularJS 服务获取数据,但不将其返回给 Controller ?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29900882/

相关文章:

javascript - JQuery Ajax 不向 PHP 发送数据

javascript - JQuery UI 对话框 : Dynamic OnClick Listener

javascript - "Save As" Angular 应用程序中 HTML5 本地存储中的文件

javascript - 是否可以使用 $logProvider 登录模块的配置 block ?

php - 当我使用 $.Ajax-Post 加载更多数据时,缓存无法处理 JS 文件

angularjs - 存储多个 Firebase 引用

angularjs - 可以/如何将 Protractor 与 chutzpah 一起使用?

javascript - AngularJS - 深层对象的属性删除

Angular 中使用的 JavaScript 模式

javascript - Vue组件中继承CSS