我已经制作了两个工厂,并从第二个工厂开始调用,在控制器中占用第二个工厂,但不是将数据作为JSON获取,而是将数据作为$$状态获取。 我是angularJS的新手尝试了许多方法,但无法解决,请帮忙。
app.factory('userDetails', ['APIService', '$q', function (APIService, $q) {
getDetails: function () {
var deferred = $q.defer();
var getFunc = function () {
APIService.doGetCall('Masters/employee/username/tarun')
.then(
function (data)
{
deferred.resolve(data);
},
function (data, status, headers, config)
{
deferred.reject('There was an error creating object'); })
return deferred.promise;
}
var a = getFunc();
return a;
}
}
vm.user = userDetails.getDetails();
console.log("user",vm.user);
响应如下面的代码段
答案 0 :(得分:0)
userDetails.getDetails()
会返回一个承诺,因此您需要使用.then(onsuccess, onRejected)
userDetails.getDetails().then(function(data){
vm.user = data;
console.log("user",vm.user);
});
答案 1 :(得分:0)
您应该使用.then
函数来获取响应。相反,我会说你不需要创造额外的承诺,它是anti-pattern
。您可以直接使用doGetCall
方法返回承诺。
app.factory('userDetails', ['APIService', '$q', function(APIService, $q) {
getDetails: function() {
var getFunc = function() {
return APIService.doGetCall('Masters/employee/username/tarun');
}
var a = getFunc();
return a;
}
}]);
vm.user = userDetails.getDetails().then(function(response){
console.log(response.data);
vm.user = response.data;
console.log("user", vm.user);
}, function(error){
console.log(error)
}).catch(exceptionHandler);
答案 2 :(得分:0)
你有
return deferred.promise;
在APIService.doGetCall函数内部。它应该在它之外。