JavaScript/jQuery Promise 链

标签 javascript jquery promise deferred

尽管我无法(保密问题)分享太多信息,但我真的希望有人可以帮助我解决这个问题。基本上,我编写这个函数是为了重试失败的 promise :

function retryOnFailure(func) {
  return func().then(function(resp) {
    return resp
  }, function(err) {
    return setTimeout(function() {
      return retryOnFailure(func)
    }, 5000)
  }
)}

然后我有这个代码来使用它:

function getStuff() {
  return $.get('/some/endpoint')
}

retryOnFailure(getStuff).then(function(res) { console.log(res) })

现在,递归重试函数工作正常,但如果在 retryOnFailure 中遇到错误情况,最后一行代码中的 then 不会触发。我知道原因是因为每个递归调用都会创建一个新的 promise ,因此我在最后一行中听到的 promise 与得到解决的 promise 不同,但我很难弄清楚如何解决这个问题。我希望这个函数成为一个通用的重试函数,因此不想处理该方法中的实际成功,但我没有看到任何其他方法。任何帮助将不胜感激!

最佳答案

return setTimeout(function() {
    return retryOnFailure(func)
}, 5000)

看起来您正在尝试做正确的事情 - 从 .catch 回调中返回下一个结果。但是,setTimeout 不会返回 Promise,因此 retryOnFailure() 将立即解决(使用超时取消 ID)。

相反,您需要确保为您使用的所有异步函数生成 Promise,因此让我们从 Promisifying setTimeout 开始:

function delay(ms) {
  return new Promise(function(resolve, reject) {
    setTimeout(resolve, ms);
  });
}

现在我们可以使用它来链接延迟后的重试,并从中获得 promise :

function retryOnFailure(func) {
  return func().then(null, function(err) {
    return delay(5000).then(function() {
      return retryOnFailure(func);
    });
  });
}

请注意,除了 .then(null, …),您还可以使用 .catch(…)

关于JavaScript/jQuery Promise 链,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31977279/

相关文章:

javascript - 如何调整对象的大小 - Autodesk Forge Viewer

javascript - 如何使用getSelection?

javascript - 在 html 中运行 jQuery 代码

javascript - 如何使用 jQuery 的 json2html 将文件内的文本渲染到另一个 html 页面中?

angularjs - 在 Angular 中,promise 的 error 和 catch 函数在概念上的区别是什么?

javascript - NodeJS Promise 行为查询

java - Netty:如何处理ChannelOutboundHandler写入中未履行的Promise

javascript - 如何通过 webpack 使用 videoJS 和 videoJS 播放列表以及 videoJS 播放列表 ui

javascript - 带点赋值的数组

php - ajax方法发布不起作用