SKY*_*ine 7 arrays foreach angularjs
我试图迭代我从一个内部的多个http调用构建的数组 angular.forEach()
功能
$scope.ticket_stats = function(){
//cleaning variables
$scope.data_set = [];
$scope.closed_tickets = [];
//fetching time stamps (epoch)
$scope.time_frame = time_period.days(7);
//calling data using time stamps
angular.forEach($scope.time_frame, function(item) {
//debug
console.log(item);
var promise = tickets.status("closed", item);
promise.success(function(data){
console.log(data);
$scope.closed_tickets.push(data[0].datapoints[0][0]); // returns a numerical value
});
});
//SEE MESSAGE BELOW
$scope.data_set.push($scope.closed_tickets);
}
Run Code Online (Sandbox Code Playgroud)
最后一行$scope.data_set.push()
正在工作但是一旦调用返回数据就会随着时间的推移自行增 我想在for Each循环中的所有内容都完成之后执行此行.我需要迭代$scope.closed_tickets
数组,然后在其中播放(添加)数据并构建第二个数组.
以下是此功能中使用的服务:
// CALL TICKETS STATS
app.service('tickets', function($http){
this.status = function(status, date){
var one_snap = date - 100;
var url = "/url/render?format=json&target=sum(stats.tickets."+status+")&from="+one_snap+"&until="+date+"";
return $http.get(url);
};
});
// TIME STAMPS MATHS
app.service('time_period', function(){
var currentDate = parseInt((new Date).getTime()/1000);
this.days = function(number){
var pending = [];
for (var i = number; i > 0; i--) {
pending.push(currentDate - (87677*i));
}
return pending;
};
});
Run Code Online (Sandbox Code Playgroud)
我搜索信息并发现有关该$q.all()
服务的信息,但没有按照我想要的方式完成这项工作.
任何建议都会受到欢迎!谢谢!
csb*_*nes 21
您可以使用$ q.all等待多个同步事件(promises)完成.
$scope.ticket_stats = function() {
// list of all promises
var promises = [];
//cleaning variables
$scope.data_set = [];
$scope.closed_tickets = [];
//fetching time stamps (epoch)
$scope.time_frame = time_period.days(7);
//calling data using time stamps
angular.forEach($scope.time_frame, function(item) {
// create a $q deferred promise
var deferred = $q.defer();
//debug
console.log(item);
tickets.status("closed", item).success(function(data) {
console.log(data);
$scope.closed_tickets.push(data[0].datapoints[0][0]);
// promise successfully resolved
deferred.resolve(data);
});
// add to the list of promises
promises.push(deferred.promise);
});
// execute all the promises and do something with the results
$q.all(promises).then(
// success
// results: an array of data objects from each deferred.resolve(data) call
function(results) {
$scope.data_set.push($scope.closed_tickets);
},
// error
function(response) {
}
);
}
Run Code Online (Sandbox Code Playgroud)
首先,deferred
代表一段代码,它将花费不明的时间来执行(异步).deferred.resolve(data)
简单地说明代码已经完成.数据可以是任何东西,对象,字符串等等,但它通常是异步代码的结果.同样,您可以拒绝承诺deferred.reject(data)
(可能是服务器引发了错误).同样,数据可以是任何东西,但在这里它可能应该是错误响应.
deferred.promise
只返回一个promise对象.promise对象允许您设置回调,.then(successFunction, errorFunction)
因此您知道一段代码已经完成执行,然后再继续successFunction
(或者errorFunction
在发生故障的情况下).在我们的例子中$q
有一个.all
方法,等待一个promises数组完成然后给你作为一个数组的所有promises的结果.
不要忘记注入$q
服务.
归档时间: |
|
查看次数: |
18902 次 |
最近记录: |