javascript - $q.all 在服务中返回 Controller 中的空对象

标签 javascript angularjs http angular-promise

您好,一段时间以来,我在使用此 api 调用时遇到了一些问题。当我调用此 API 时,服务中的 console.log 返回我需要的内容,但 Controller 未收到它并返回一个空对象。我想我可能做错了什么,当我返回我的 promise 时,但我找不到问题。我目前正在使用 $q.all() 链接多个获取请求。

这是我的 Controller 功能代码:

    $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 但我的控制台出现错误:

cannot read property 'then' of undefined

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

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

在我发回 promise 之前,我想知道是否有办法从对象数组中获取 dataIwant 对象。如果有人能帮助我,我将不胜感激

最佳答案

您正在返回 $q 的另一个空副本。只需从服务返回原始的 $q.all promise

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

然后在 Controller 中执行此操作:

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

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

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

在 Controller 中以同样的方式处理它。

关于javascript - $q.all 在服务中返回 Controller 中的空对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37647753/

相关文章:

http - 嵌套的 ServeMux 总是返回 "301 Moved Permanently"

javascript - 如何获取已更改元素的外部样式表数据?

javascript - 检测 NoScript(不是标签,扩展名)

javascript - 下拉警报始终在屏幕顶部 - AngularJS

java - 什么是 Java 等同于使用 https ://fcm. googleapis.com/fcm/send REST Api

javascript - HTTP 重试更改 url 的参数

javascript - yii2:处理 gridview 的选定行不起作用 - ajax 帖子为空

javascript - 在 jQuery 中使用 $.data() 在元素上存储标志

javascript - 使用动态源将动画保留在 ng-include 上

javascript - Angular中的http服务发送post数据作为请求正文的键,没有值