我有一个用例,我需要使用for-loop,webservice回调,一起超时,然后我发现超时似乎不起作用,这里是代码:
function handler5Min(i){
if (i < sites.length){
var site5MinPath = '/v3/sites/' + sites[i].siteid + '/data?fields=Wh_sum&tz=US/Pacific&gran=daily';
var end = moment().format('YYYY-MM-DDThh:mm:ss');
var start = moment().subtract(2, 'days').format('YYYY-MM-DDThh:mm:ss');
site5MinPath = site5MinPath + '&start=' + start + '&end=' + end;
var options = locusUtil.setOptions(site5MinPath, globalToken.token.access_token);
request(options, function(err, result, body){
if (err){
log.error(err + ' path: ' + site5MinPath);
}
if (body){
var data = JSON.parse(body).data;
log.info('5 min data: ' + JSON.stringify(body, null, 4));
setTimeout(handler5Min(i+1), 5000);
}
})
}
else{
}
}
handler5Min(0);
请求发送一个webservice请求,我需要等到得到响应然后我移动到下一个site []项目进行下一次调用,而且,API提供者将请求限制为每秒2,所以我有一个setTimeout在那里,但似乎超时没有发生。
答案 0 :(得分:1)
而不是做
setTimeout(handler5Min(i+1), 5000);
DO
setTimeout(handler5Min, 5000, i + 1);