繁体   English   中英

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

[英]AngularJS factory returning State object instead of JSON data from 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);

响应如下面的片段

响应

userDetails.getDetails()返回一个promise,因此你需要使用.then(onsuccess, onRejected)

userDetails.getDetails().then(function(data){
   vm.user = data;
   console.log("user",vm.user);
});

你应该使用.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);

你有

return deferred.promise;

APIService.doGetCall函数内的一行。 它应该在它之外。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM