for循环,回调,超时一起,超时似乎不起作用

时间:2016-02-26 02:01:45

标签: javascript for-loop callback settimeout

我有一个用例,我需要使用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在那里,但似乎超时没有发生。

1 个答案:

答案 0 :(得分:1)

而不是做

setTimeout(handler5Min(i+1), 5000);

DO

setTimeout(handler5Min, 5000, i + 1);