javascript - 为什么我的 do..while 循环没有正确执行异步等待代码中的 setTimeout?

标签 javascript promise async-await do-while

我有一个执行 promise 并等待响应的 do..while 循环。当响应为“正在处理”或“已接收”时,循环需要继续。但是,Promise 中有一个 setTimeout 函数。

这里的目标是函数 respo = await promise1.then(resp => resp),在 do..while 循环的“do”语句中,仅在 2 之后被调用秒。这只是为了让我正在使用的 API 完成它的工作。

当前发生的情况是 setTimeout 被调用一次并且循环几乎立即重复相同的响应,表明 2 秒中断不起作用。

我做错了什么?

const promise1 = new Promise(function (resolve, reject) {
  setTimeout(function () {
    resolve(tasks(resStatus.data.task.id, tokenTenant))
  }, 2000);
})

do {
  respo = await promise1
  console.log(respo.data)
} while (respo.data.status === "Processing" || respo.data.status === "Received");

. . .

为那些好奇的人提供的一些示例响应(问题已解决):

ALL SYSTEMS GO!
{ id: 'd23b2cf3-02c3-48fe-9479-1407238d41d9',
  status: 'Received',
  result: null,
  tenant_id: 'eaa55f40-93fa',
  creation_time: '2019-04-25T18:19:47+0000' }

****...some results omitted for brievety...****

{ id: 'd23b2cf3-02c3-48fe-9479-1407238d41d9',
  status: 'Processing',
  result: null,
  tenant_id: 'eaa55f40-93fa',
  creation_time: '2019-04-25T18:19:47+0000' }
{ id: 'd23b2cf3-02c3-48fe-9479-1407238d41d9',
  status: 'Failed',
  result: { Reason: '[Errno 22] Invalid argument' },
  tenant_id: 'eaa55f40-93fa',
  creation_time: '2019-04-25T18:19:47+0000' }

最佳答案

几点说明:

  • 一个 promise 只能解决一次。
  • 传递给 Promise 构造函数的回调立即执行,之后不再执行

解决方案:将 const promise1 = ... 定义移到循环内。这样您就可以在每次迭代中创建一个新的 promise 。

关于javascript - 为什么我的 do..while 循环没有正确执行异步等待代码中的 setTimeout?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55855243/

相关文章:

c# - 等待网络会导致客户端超时吗?

Javascript:如何通过按钮将事件添加到 Outlook 日历

javascript - 如何确保所有使用 redux 的 promise 的正确顺序?

c# - 单元测试和多个异步任务

javascript - promise 没有以我期望的方式解决

javascript - 使用异步 while 循环创建和插入文档

javascript - 异步等待单元测试问题

javascript - 如何对通过模板生成的按钮使用 onclick 事件?

javascript - Jquery UI 调整文本大小取决于父 div 和屏幕大小

javascript - URL 中最后一个斜杠与哈希值之间的匹配