forEach 和 for...of... 在遍历内部存在异步操作的区别
创始人
2024-11-05 02:07:20
0

起先是因为一段代码:

const formatUserInfo = async (id) => {   const result = await getUserInfoByIdAPI(id)   return result.data.data } const getReturnSchoolInfoList = async () => {   const result = await getReturnSchoolInfoListAPI(page.value, limit.value)   count.value = result.data.data.count   returnSchoolInfoList.value = result.data.data.rows   // todo 根据userId 获取用户信息 并与返校信息合并   returnSchoolInfoList.value.forEach(item => {     const result1 = await formatUserInfo(item.userId)     console.log(result1)     item.userInfo = result1   })   console.log(returnSchoolInfoList.value) } 

然后报错: [vite] Internal server error: [vue/compiler-sfc] Unexpected reserved word ‘await’.。

如果去掉 await ,那么由于是异步操作会先输出 returnSchoolInfoList.value,再输出 result1,并且因为赋值的时候并没有获取到result1 的具体值,所以需等待该异步操作完成后再进行赋值。

然后幸好有 Webstorm 的智能提示,让我使用 for…of… 代替 forEach,bug 果然消失了 !

const formatUserInfo = async (id) => {   const result = await getUserInfoByIdAPI(id)   return result.data.data } const getReturnSchoolInfoList = async () => {   const result = await getReturnSchoolInfoListAPI(page.value, limit.value)   count.value = result.data.data.count   returnSchoolInfoList.value = result.data.data.rows   // todo 根据userId 获取用户信息 并与返校信息合并   for (const item of returnSchoolInfoList.value) {     const result1 = await formatUserInfo(item.userId)     console.log(result1)     item.userInfo = result1   }   console.log(returnSchoolInfoList.value) } 

并且等待异步完成后,正确赋值了!

相关内容

热门资讯

透视黑科技!wepoker钻石... 透视黑科技!wepoker钻石怎么看底牌(透视)从来有挂(详细辅助系统教程);1分钟了解详细教程(微...
透视脚本!wepoker免费永... 透视脚本!wepoker免费永久脚本(透视)详细辅助透明挂教程(一直真的有挂)1、在wepoker免...
透视科技!aapoker透视怎... 透视科技!aapoker透视怎么用,德普软件(详细辅助必胜教程)aapoker透视怎么用软件透明挂微...
透视规律(wePOKE)wep... 透视规律(wePOKE)wepower让系统发好牌(透视)详细辅助分享教程关于wepower让系统发...
透视最新!aapoker能控制... 1、透视最新!aapoker能控制牌吗(透视)原来有挂(详细辅助大神讲解);详细教程。2、aapok...
透视辅助!aapoker辅助是... 透视辅助!aapoker辅助是真的吗,werplan怎么透视(详细辅助介绍教程)1、下载好aapok...
透视实锤!wpk辅助器安装(透... 透视实锤!wpk辅助器安装(透视)详细辅助微扑克教程(一直有挂)1、全新机制【wpk辅助器安装软件透...
透视透视(WePoKer)wp... 透视透视(WePoKer)wpk发牌算法(透视)详细辅助介绍教程;支持2-10人实时对战,虚拟庄家发...
透视工具!拱趴大菠萝辅助神器(... 透视工具!拱趴大菠萝辅助神器(透视)果然真的有挂(详细辅助细节方法);支持2-10人实时对战,虚拟庄...
透视透视!智星德州菠萝插件官网... 透视透视!智星德州菠萝插件官网,智星德州插件2024最新版(详细辅助黑科技教程);1、实时智星德州菠...