声明一个数组:⬇️
const skills = ['js', 'vue', 'node', 'react']
再声明一个promi的异步代码: ⬇️
function getskillpromi (value) { return new promi((resolve, reject) => { ttimeout(() => { resolve(value) }, 1000) })}
由于for循环并非函数,而async、await需要在函数中使用,因此需要在for循环外套一层function
async function test () { for (let i = 0; i < skills.length; i++) { const skill = skills[i] const res = await getskillpromi(skill) console.log(res) }}test() // 调用
当使用await时,希望javascript暂停执行,直到等待 promi 返回处理结果。上述结果意味着for循环中有异步代码,是可以等到for循环中异步代码完全跑完之后再执行for循环后面的代码。
但是他不能处理回调的循环,如foreach、map、filter等,下面具体分析。
在map中使用await, map 的返回值始是promi数组,这是因为异步函数总是返回promi。
async function test () { console.log('start') const res = skills.map(async item => { return await getskillpromi(item) }) console.log(res) console.log('end')}test()
结果:始终为promi数组
start[ promi { <pending> }, promi { <pending> }, promi { <pending> 森林防火顺口溜}, promi { <pending> }]end
若果你想要等到promi的返回结果,可以使用promi.all()处理一下
async function test () { console.log('start') const res = skills.map(async item => { return await getskillpromi(item) }) const respromi = await promi.all(res) console.log(respromi) console.log('end')}test()// 结果start[ 'js', 'vue', 'node', 'react' ]end
先上代码和结果
async function test () { console.log('start') skills.foreach(async item => { const res = await getskillpromi(item) conso对祖国的祝福le.log(res) }) console.log('end')}test()
预期结果
‘start’
‘js’
‘vue’
‘node’
‘react’
‘end’
实际结果 在foreach循环等待异步结果返回之前就执行了console.log(‘end’)
‘start’
‘end’
‘js’
‘vue’
‘node’
‘react’
javascript 中的 foreach不支持 promi 感知,也支持 async 和await,所以不能在 foreach 使用 await 。
使用filter过滤item为vue或者react的选项
正常使用 filter:
async function test () { console.log('start') const res = skills.filter(item => { re四川美食排行榜turn ['vue', 'react'].includes(item) }) console.log(res) console.log('end')}test() // 调用// 结果start[ 'vue', 'react' ]end
使用 await后:
async function test () { console.log('start') const res = skills.filter(async item => { const skill = await getskillpromi(item) return ['vue', 'react'].includes(item) }) console.log(res) console.log('end')}test()
预期结果:
start
[ ‘vue’, ‘react’ ]
end
实际结果:
[ ‘js’, ‘vue’, ‘node’, ‘react’ ]
end
结论:因为异步函数getskillpromi返回结果返回的promi总是真的,所以所有选海内项都通过了过滤
结语:由于工作中遇到了,异步校验是遇到了此问题,后来经过查阅资料总结出来的结果
到此这篇关于js循环中正确使用async、await的文章就介绍到这了,更多相关js循环中使用async、await内容请搜索www.887551.com以前的文章或继续浏览下面的相关文章希望大家以后多多支持www.887551.com!
本文发布于:2023-04-04 03:42:20,感谢您对本站的认可!
本文链接:https://www.wtabcd.cn/fanwen/zuowen/a633dbb0dc2883451492c773ad85916c.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文word下载地址:JS循环中正确使用async、await的姿势分享.doc
本文 PDF 下载地址:JS循环中正确使用async、await的姿势分享.pdf
留言与评论(共有 0 条评论) |