我想在加载页面时进行3次API调用以获取必要的数据。 我的申请是在AngularJS#1.5.8中。我可以在服务中单独提供数据,但由于某种原因,在控制器中,第一次API调用的数据全部返回3次。 3 API调用之间没有依赖关系。
这是我的控制器代码
// app.module.js
(function () {
angular
.module('SomeAppName', [])
.controller('DDCtrl', DDCtrl);
DDCtrl.$inject = ['$scope', 'ApiService']
function DDCtrl($scope, ApiService) {
var vm = this;
vm.qddData = [];
vm.rddData = [];
vm.sddData = [];
activate();
function activate() {
ApiService.getNumberData('api/get.first.data.php')
.then(function (firstdata) {
console.log(firstdata);
vm.qddData = firstdata;
return ApiService.getNumberData('api/get.second.data.php');
})
.then(function (seconddata) {
console.log(seconddata); // logs firstdata instead of seconddata
vm.rddData = seconddata;
return ApiService.getNumberData('api/get.third.data.php');
})
.then(function (thirddata) {
console.log(thirddata); // logs firstdata instead of thirddata
vm.sddData = thirddata;
})
.catch(function (err) {
console.log(err.data);
});
}
}
})();
这是我的数据服务
// app.service.js
(function () {
angular
.module('SomeAppName')
.factory('ApiService', ApiService);
ApiService.$inject = ['$http', '$q'];
function ApiService($http, $q) {
var deferred = $q.defer();
return {
getNumberData: getNumberData
};
function getNumberData(dictUrl) {
return $http.get(apiUrl)
.then(getRequestComplete)
.catch(getRequestFailed);
}
function getRequestComplete(response) {
console.log(response.data); // here the data is logged correctly
deferred.resolve(response.data);
return deferred.promise;
}
function getRequestFailed(error) {
deferred.reject(error);
return deferred.promise;
}
}
})();
答案 0 :(得分:1)
威胁在ApiService
内,您为所有defer
请求维护单http
个对象,这是不正确的。相反,我可以说,您不需要创建自定义promise
(它被视为反模式)。只需通过$http.get
&通过从success
回调中返回数据来链接它。
<强>代码强>
(function () {
angular
.module('SomeAppName')
.factory('ApiService', ApiService);
ApiService.$inject = ['$http', '$q'];
function ApiService($http, $q) {
//no need to create a custom defer object at all
//var deferred = $q.defer();
return {
getNumberData: getNumberData
};
function getNumberData(dictUrl) {
return $http.get(apiUrl)
.then(getRequestComplete)
.catch(getRequestFailed);
}
function getRequestComplete(response) {
return response.data; //return a data to chain promise with success
}
function getRequestFailed(error) {
return $q.reject(error); //reject to call error function of subsequent chain promise
}
}
})();