AngularJS工厂返回State对象而不是promise中的JSON数据

时间:2016-09-23 07:15:51

标签: javascript angularjs json angular-promise

我已经制作了两个工厂,并从第二个工厂开始调用,在控制器中占用第二个工厂,但不是将数据作为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);

响应如下面的代码段

Response

3 个答案:

答案 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函数内部。它应该在它之外。