你好我有一段时间这个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 对象。如果有人能帮助我,我会非常感激
答案 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;
});
});
在控制器中处理它的方式相同。