我正在尝试测试一种在 JavaScript 中重试失败的异步函数的方法。
按照 https://stackoverflow.com/a/31630063/3094668 中的示例,我做了一个JSFiddle http://jsfiddle.net/tdb3sa8k/19/
function doAsync(i) {
console.log("doAsync " + i);
return Promise.resolve();
}
function ayncFunc() {
return doAsync(-1).catch(doAsync(0)).catch(doAsync(1)).catch(doAsync(2));
};
var retries = 3;
function ayncFunc2() {
var p = doAsync(-1);
for (var i=0; i < retries; i++) {
p = p.catch(doAsync(i));
}
return p;
};
function ayncFunc3() {
function recurse(i) {
return doAsync(i).catch(function(e) {
if (i < retries) {
return recurse(++i);
}
throw e;
});
}
return recurse(0);
};
ayncFunc().catch(function(e) { console.log(e); })
.then(ayncFunc2).catch(function(e) { console.log(e); })
.then(ayncFunc3).catch(function(e) { console.log(e); });
我遇到的问题是,尽管 doAsync 函数返回已解决的 promise ,但代码落在 catch block 中并执行重试。
请注意,代码中有3种重试机制的方法。 (ayncFunc、ayncFunc2 和 ayncFunc3)。 ayncFunc3 似乎有效,但前两者给出了意想不到的结果。 (doAsync 应该只运行一次)。
现在的输出是
doAsync -1 异步 0 异步1 doAsync 2
doAsync -1 异步 0 异步1 doAsync 2
doAsync 0
任何帮助或见解将不胜感激!
最佳答案
您想要传递一个在 catch 上执行的函数,但实际上您立即执行该函数并传递结果 promise :
p = p.catch(doAsync(i));
必须是:
p = p.catch(() => doAsync(i));
关于尽管 Promise.resolve() ,Promise catch block 中的 Javascript 重试异步函数始终运行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52004593/