【发布时间】:2015-06-19 14:13:15
【问题描述】:
我有一个 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);
}
});
【问题讨论】:
-
您使用什么库来进行 Web 服务调用?您正在使用的库可能已经有一个超时设置,您可以使用它而不是尝试明确地这样做。
-
不幸的是,这是一段遗留的代码,我想尽可能避免接触!
标签: javascript function callback timeout