$ q.all在服务器中返回控制器中的空对象

时间:2016-06-05 23:23:26

标签: javascript angularjs http angular-promise

你好我有一段时间这个api调用遇到了一些问题。当我进行这个API调用时,我的服务中的console.log返回我需要的内容,但控制器没有收到它并返回一个空对象。当我回复我的承诺时,我想我可能做错了什么,但我找不到问题。我目前正在使用$ q.all()来链接多个获取请求。

这是我的代码我的控制器功能:

    $scope.getData = function(input) {
    exampleService.getData(input)
        .then(function(data) {
            console.log(data);
            $scope.savedData = data;
    }, function(error) {
          alert(error); // just sends an alert with -1 if error
    });
};

现在这是我的服务功能

this.getData = function(input) {
$q.all([
    $http.get(url1),
    $http.get(url2)
]).then(function(response) {
    console.log(response); //returns array of objects that I want
    return response;
});
return $q.all();
};

现在我尝试返回 $ q.all()。promises ,但我的控制台出错了:

  

无法读取未定义的属性“然后”

我最终想要访问数组中每个对象中的一个属性,这也是嵌套在对象中的对象,例如

var returnedPromise = [
     {dataIDontNeed:1, {dataIwant}},
     {dataIDontNeed:2, {dataIwant}},
     {dataIDontNeed:3, {dataIwant}}
]

我想知道在发回承诺之前是否有办法从对象数组中获取 dataIwant 对象。如果有人能帮助我,我会非常感激

1 个答案:

答案 0 :(得分:3)

您将返回$ q的另一个空的副本。只需从服务中返回原始的$ q.all承诺

return $q.all([ $http.get(url1), $http.get(url2) ]);

在控制器中执行此操作:

service.getData({}).then(...

如果您想要转换结果,只需将另一个即时解决的承诺链接到all函数。如果数据看起来像你说的那样,只需删除你不想要的属性:

return $q.all([ $http.get(url1), $http.get(url2) ]).
then(function(results){
    return results.map(function(each){
        delete each.dataIDontNeed;
        return each;
    });
    });

在控制器中处理它的方式相同。