文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

JS循环中正确使用async、await的方法是什么

2023-06-22 03:05

关注

JS循环中正确使用async、await的方法是什么,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。

概览(循环方式 - 常用)

声明遍历的数组和异步方法

声明一个数组:⬇️

const skills = ['js', 'vue', 'node', 'react']

再声明一个promise的异步代码: ⬇️

function getSkillPromise (value) {  return new Promise((resolve, reject) => {    setTimeout(() => {      resolve(value)    }, 1000)  })}

for 循环中使用

由于for循环并非函数,而async、await需要在函数中使用,因此需要在for循环外套一层function

async function test () {  for (let i = 0; i < skills.length; i++) {    const skill = skills[i]    const res = await getSkillPromise(skill)    console.log(res)  }}test() // 调用

JS循环中正确使用async、await的方法是什么

当使用await时,希望JavaScript暂停执行,直到等待 promise 返回处理结果。上述结果意味着for循环中有异步代码,是可以等到for循环中异步代码完全跑完之后再执行for循环后面的代码。

但是他不能处理回调的循环,如forEach、map、filter等,下面具体分析。

map 中使用

在map中使用await, map 的返回值始是promise数组,这是因为异步函数总是返回promise。

async function test () {  console.log('start')  const res = skills.map(async item => {    return await getSkillPromise(item)  })  console.log(res)  console.log('end')}test()

结果:始终为promise数组

start[  Promise { <pending> },  Promise { <pending> },  Promise { <pending> },  Promise { <pending> }]end

若果你想要等到promise的返回结果,可以使用promise.all()处理一下

async function test () {  console.log('start')  const res = skills.map(async item => {    return await getSkillPromise(item)  })  const resPromise = await Promise.all(res)  console.log(resPromise)  console.log('end')}test()// 结果start[ 'js', 'vue', 'node', 'react' ]end

forEach 中使用

先上代码和结果

async function test () {  console.log('start')  skills.forEach(async item => {    const res = await getSkillPromise(item)    console.log(res)  })  console.log('end')}test()

预期结果

'Start'

'js'

'vue'

'node'

'react'

'End'

实际结果 在forEach循环等待异步结果返回之前就执行了console.log('end')

'Start'

'End'

'js'

'vue'

'node'

'react'

JavaScript 中的 forEach不支持 promise 感知,也支持 async 和await,所以不能在 forEach 使用 await 。

filter 中使用

使用filter过滤item为vue或者react的选项

正常使用 filter:

async function test () {  console.log('start')  const res = skills.filter(item => {    return ['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 getSkillPromise(item)    return ['vue', 'react'].includes(item)  })  console.log(res)  console.log('end')}test()

预期结果:

start

[ 'vue', 'react' ]

end

实际结果:

[ 'js', 'vue', 'node', 'react' ]

end

结论:因为异步函数getSkillPromise返回结果返回的promise总是真的,所以所有选项都通过了过滤

  1. 如果你想连续执行await调用,请使用for循环(或任何没有回调的循环)。

  2. 永远不要和forEach一起使用await,而是使用for循环(或任何没有回调的循环)。

  3. 不要在 filter 和 reduce 中使用 await,如果需要,先用 map 进一步骤处理,然后在使用 filter 和 reduce 进行处理。

关于JS循环中正确使用async、await的方法是什么问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注编程网行业资讯频道了解更多相关知识。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     801人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     348人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     311人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     432人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     220人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯