[英]AngularJS return value from factory to controller out of Promise
我在.factory中将HTTP请求设置为Promise,并希望将结果发送到控制器。 但是,我一直坚持将数据从承诺中转移到我可以使用的地方。
.controller
.controller('MainCtrl', function ($scope, Main, User) {
$scope.feedResult = function () {
var feeds = [];
return Main.feed(key).success(function (data, status, headers, config) {
for (var i = 0; i < data.length; i += 1)
{
feeds.push(data[i]);
}
return feeds;
}).error(function (data, status, headers, config) {
console.log("This was an error back from the server");
console.log(data);
return data;
});
}();
})
和.factory
feed: function (token) {
return $http({
url: 'http://myserver.com/feed',
method: 'GET',
data: {
auth_code: token,
per_page: 10
}
}).success(function (data, status, headers, config) {
for (var i = 0; i < data.length; i += 1)
{
feeds.push(data[i]);
}
return feeds;
}).error(function (data, status, headers, config) {
console.log("This was an error back from the server");
console.log(data);
return data;
});
},
不管我如何尝试将事情放到范围内,我似乎总是以promise对象告终。 有人可以帮我吗?
成功或错误方法将始终返回一个承诺(它将您的返回值包装到一个新的承诺中)。 您应该在成功/错误回调中设置作用域上的值:
.controller('MainCtrl', function ($scope, Main, User) {
$scope.feedResult = [];
Main.feed(key).success(function (data, status, headers, config) {
for (var i = 0; i < data.length; i += 1)
{
$scope.feedResult.push(data[i]);
}
}).error(function (data, status, headers, config) {
console.log("This was an error back from the server");
console.log(data);
$scope.feedResult = data;
});
})
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.