Javascript函数回调依赖于超时

时间:2015-04-14 04:49:12

标签: javascript function callback timeout

我有一个javascript函数,它向Web服务发出请求并操纵响应。

我想在函数中设置超时,因为Web服务有时会不稳定。

在我的下面的示例中,我有两个超时,第二个将被Web服务的请求所取代。但是在下面的示例中,回调仍然运行两次。我是否以正确的方式进行此操作,如何在返回错误回调后停止该函数。

function fnWithTimeoutCallback(v1, v2, callback) {

    // set a timeout after 3 seconds

    setTimeout(function(){

        var err = true;

        var res = {};
        res.status = 'error';
        res.message = 'Request timed out.';

        return callback(err, res);

    }, 3000);

    // meanwhile do a bunch of stuff which makes requests to web services etc

    setTimeout(function(){

        var err = false;

        var res = {};
        res.status = 'success';
        res.message = 'Did stuff with web service.';

        return callback(err, res);

    }, 6000);

}


fnWithTimeoutCallback('v1', 'v2', function(err, res) {

    if(err) { 
        console.log('There was an error: ' + res.message);
    } else {
        console.log('Worked!' + res.message);
    }

});

1 个答案:

答案 0 :(得分:0)

您可以使用clearTimeout函数来清除超时,您需要将setTimeout保存到变量并根据需要清除。

var timeout1 = setTimeout (function(){
//check and clear timeout2
  clearTimeout(timeout2);
},6000);

var timeout2 = setTimeout (function(){
//check and clear timeout1
clearTimeout(timeout1);
},6000);