当前位置:  开发笔记 > 编程语言 > 正文

异步/等待,"未解析的变量或类型等待"

如何解决《异步/等待,"未解析的变量或类型等待"》经验,为你挑选了1个好方法。

为了使用await,它内部的功能需要async.例如:

(async () => {
  let usersInAuth0 = [];    
  for (let i = 0; i < 5; i++) {
    const usersInAuth0InPage = await getUsersFromAuth0(i); // error in webstorm
    if (_.isEmpty(usersInAuth0InPage)){
      return res.status(200).send(usersInAuth0);
    } else {
      usersInAuth0.push(usersInAuth0InPage);
    }
  }

  const getUsersFromAuth0 = page => management.getUsers({per_page:100, page: page});
})();

https://codereviewvideos.com/blog/unresolved-variable-type-await/

请注意,由于management.getUsers返回Promise,您不需要进行getUsersFromAuth0异步 - 只需返回promise await及其分辨率更高.

因为async函数返回promises,所以你需要确保消耗整个代码块的任何东西能够处理它的返回值是一个promise.(您return res.status(200).send(usersInAuth0);实际上不会返回该值 - 如果条件内部有条件,函数将返回一个解析为该值的promise )



1> CertainPerfo..:

为了使用await,它内部的功能需要async.例如:

(async () => {
  let usersInAuth0 = [];    
  for (let i = 0; i < 5; i++) {
    const usersInAuth0InPage = await getUsersFromAuth0(i); // error in webstorm
    if (_.isEmpty(usersInAuth0InPage)){
      return res.status(200).send(usersInAuth0);
    } else {
      usersInAuth0.push(usersInAuth0InPage);
    }
  }

  const getUsersFromAuth0 = page => management.getUsers({per_page:100, page: page});
})();

https://codereviewvideos.com/blog/unresolved-variable-type-await/

请注意,由于management.getUsers返回Promise,您不需要进行getUsersFromAuth0异步 - 只需返回promise await及其分辨率更高.

因为async函数返回promises,所以你需要确保消耗整个代码块的任何东西能够处理它的返回值是一个promise.(您return res.status(200).send(usersInAuth0);实际上不会返回该值 - 如果条件内部有条件,函数将返回一个解析为该值的promise )

推荐阅读
和谐啄木鸟
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有