await 一个递归函数怎么才能正确执行 ?

发布于 2022-09-12 03:42:14 字数 464 浏览 37 评论 0

preUpload: async function (e) {
    ……
    await the.multiUpload({
      path: pics
    })
    console.log('upload result: ', data)
  }
multiUpload: async function (data) {
    ……
    if (i < data.path.length) {
      multiUpload(data) //递归,回调自己
    } else {
      wx.hideLoading()
    }
    ……
  }

当前 multiUpload 没有执行完,就输出 upload result 了

由于是递归,不清楚 promise 应该写在哪 … 试着将 resolve 写道 else 中,结果并没有执行 …

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(4

盛装女皇 2022-09-19 03:42:14

你的 multiUpload 里没有 return,所以被当作 return null,所以就没法 await 了。

另外,如果是批量上传,这种递归并没有好处,还不如搞成队列或者 Promise.all

往日情怀 2022-09-19 03:42:14
demo().then(res => {
  console.log('执行完毕:', res)
});


// 例如执行5次返回成功
function demo (count) {
  count = count || 0;
  return new Promise(resolve => {
    // 1 秒执行一次
    setTimeout(async () => {
      console.log('第' + count +'次')
      if(count == 5) {
        resolve(count);
      } else {
        resolve(await demo(++count));
      }
    }, 1000)
  })
}
雨的味道风的声音 2022-09-19 03:42:14

multiUpload(data)前加个await

酒几许 2022-09-19 03:42:14
const fn = async (n) => {
    if (n < 0) return;
    await fn1(n);
    fn(n - 1);
}

const fn1 = (n) => {
    return new Promise((resolve, reject) => {
        setTimeout(() => {
            console.log(n);
            resolve(n-1);
        }, 1000);
    })
}

fn(10);



const fn2 = (n) => {
    return new Promise((resolve, reject) => {
        if (n < 0) return reject();
        setTimeout(() => {
            console.log(n);
            resolve(fn2(n-1));
        }, 1000);
    })
}

fn2(10)
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文