聊聊JS循环中使用await会产生什么“化学反应”
本篇文章给大家带来了关于JavaScript循环的相关知识,其中主要给大家聊聊在js循环中怎么使用使用await以及结果分析,感兴趣的朋友一起来看一下吧,希望对大家有帮助。
前言
这个问题是这样产生的?某天,在学习异步的知识遇到这样一道题:使用Promise的方式,每隔一秒输出数组中一个值
const arr = [1, 2, 3] arr.reduce((pre, cur) => { return pre.then(() => { return new Promise((resolve, reject) => { setTimeout(() => { resolve(console.log(cur)) }, 1000); }) }) }, Promise.resolve())
那这段代码还是挺好了解的,相当于
Promise.resolve().then(() => { return new Promise((resolve, reject) => { setTimeout(() => { resolve(console.log(1)) }, 1000); }) }).then(() => { return new Promise((resolve, reject) => { setTimeout(() => { resolve(console.log(2)) }, 1000); }) }).then(() => { return new Promise((resolve, reject) => { setTimeout(() => { resolve(console.log(3)) }, 1000); }) })
看完之后,我就在想,如果我在循环中,每次输出值之后停止一秒,也可以解决,于是乎就有了以下代码
const arr = [1, 2, 3] const sleep = (ms) => { return new Promise((resolve, reject) => { setTimeout(() => { resolve() }, ms) }) } for (let i = 0; i < arr.length; i++) { console.log(arr[i]); await sleep(1000) }
打印结果也是符合预期的,在这里我就产生了第一个疑问:await不是要搭配async使用的么?这里怎么能单独使用?(不信你把代码放到浏览器控制台试试)
接着我把for改成了forEach,发现根本达不到效果,第二个疑问产生:forEach中await为什么失效了呢?
arr.forEach(async item => { console.log(item); await sleep(1000) })
带着这两个疑问,那就开始学习起来,寻找答案。
在for循环中的await
记得在学习async/await的时候有这样一句话,await只能和async搭配一起使用,其实这句话是没有错的。那为什么前面可以直接写await呢,因为我是直接写在浏览器控制台的,咱们在编辑器写代码的时候一定要套一个async使用的
<script> const arr = [1, 2, 3] const sleep = (ms) => { return new Promise((resolve, reject) => { setTimeout(() => { resolve() }, ms) }) } const logByOneSecond = async () => { for (let i = 0; i < arr.length; i++) { console.log(arr[i]); await sleep(1000) } } logByOneSecond() </script>
所以这就算闹了个笑话,哈哈,不过当我遇到不理解的时候,又多了一个思考方向。
好的,如上所述,await确实发挥了他的作用,让JS直到等到了promise返回的处理结果,再继续往下执行;那for...of,while是不是也可以呢
const logByForof = async () => { for (const item of arr) { console.log(item); await sleep(1000) } } logByForof()
const logByWhile = async () => { let i = 0 while (i !== arr.length) { await sleep(1000) console.log(arr[i]); i++ } } logByWhile()
结果也是符合预期,可以在循环中使用await并实现效果
在forEach循环中的await
如一开始,在forEach中并没有的到预期的效果;首先得到一个结果:forEach中async 和await是无效的。
那我看到的解释有以下几种
JavaScript 中的 forEach不支持 promise 感知,也不支持 async 和await,所以不能在 forEach 使用 await 。
map/forEach内部使用了while结合callback方式来执行函数,await不会等待callback的执行
forEach 只支持同步代码
第二种说法,简化以后的伪代码,如下
while(index < arr.length){ callback(item, index) }
map/forEach是简单的执行下回调函数,并不会处理异步的情况。即:map/forEach 会同时创建出多个回调函数,多个回调函数被加上了各自的 async、await,如下
async ()=>{ await sleep(1000); } async ()=>{ await sleep(1000); } async ()=>{ await sleep(1000); }
各个函数之间是独立的,彼此的回调也是独立的;请求是异步的,彼此之间又没有关联,顺序也就自然无法保证
总结
回顾了 async/await 在循环语句里的使用方法,对于普通的 for-loop,所有的 await 都是串行调用的,可以放心使用,包括 while、for-in、for-of 等等;但是在有 callback 的 array 方法,如 forEach、map、filter、reduce 等等,有许多副作用,最好就别使用 await 了。
【推荐学习:javascript高级教程】
以上是聊聊JS循环中使用await会产生什么“化学反应”的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

如何使用WebSocket和JavaScript实现在线语音识别系统引言:随着科技的不断发展,语音识别技术已经成为了人工智能领域的重要组成部分。而基于WebSocket和JavaScript实现的在线语音识别系统,具备了低延迟、实时性和跨平台的特点,成为了一种被广泛应用的解决方案。本文将介绍如何使用WebSocket和JavaScript来实现在线语音识别系

WebSocket与JavaScript:实现实时监控系统的关键技术引言:随着互联网技术的快速发展,实时监控系统在各个领域中得到了广泛的应用。而实现实时监控的关键技术之一就是WebSocket与JavaScript的结合使用。本文将介绍WebSocket与JavaScript在实时监控系统中的应用,并给出代码示例,详细解释其实现原理。一、WebSocket技

如何使用WebSocket和JavaScript实现在线预约系统在当今数字化的时代,越来越多的业务和服务都需要提供在线预约功能。而实现一个高效、实时的在线预约系统是至关重要的。本文将介绍如何使用WebSocket和JavaScript来实现一个在线预约系统,并提供具体的代码示例。一、什么是WebSocketWebSocket是一种在单个TCP连接上进行全双工

如何利用JavaScript和WebSocket实现实时在线点餐系统介绍:随着互联网的普及和技术的进步,越来越多的餐厅开始提供在线点餐服务。为了实现实时在线点餐系统,我们可以利用JavaScript和WebSocket技术。WebSocket是一种基于TCP协议的全双工通信协议,可以实现客户端与服务器的实时双向通信。在实时在线点餐系统中,当用户选择菜品并下单

JavaScript教程:如何获取HTTP状态码,需要具体代码示例前言:在Web开发中,经常会涉及到与服务器进行数据交互的场景。在与服务器进行通信时,我们经常需要获取返回的HTTP状态码来判断操作是否成功,根据不同的状态码来进行相应的处理。本篇文章将教你如何使用JavaScript获取HTTP状态码,并提供一些实用的代码示例。使用XMLHttpRequest

JavaScript和WebSocket:打造高效的实时天气预报系统引言:如今,天气预报的准确性对于日常生活以及决策制定具有重要意义。随着技术的发展,我们可以通过实时获取天气数据来提供更准确可靠的天气预报。在本文中,我们将学习如何使用JavaScript和WebSocket技术,来构建一个高效的实时天气预报系统。本文将通过具体的代码示例来展示实现的过程。We

JavaScript中的HTTP状态码获取方法简介:在进行前端开发中,我们常常需要处理与后端接口的交互,而HTTP状态码就是其中非常重要的一部分。了解和获取HTTP状态码有助于我们更好地处理接口返回的数据。本文将介绍使用JavaScript获取HTTP状态码的方法,并提供具体代码示例。一、什么是HTTP状态码HTTP状态码是指当浏览器向服务器发起请求时,服务

用法:在JavaScript中,insertBefore()方法用于在DOM树中插入一个新的节点。这个方法需要两个参数:要插入的新节点和参考节点(即新节点将要被插入的位置的节点)。
