“JavaScript 循环中的 ‘await‘

 

目录

前言

for使用await -- 有效的

forEach使用await --  无效的

for of 使用await 有效的

for await of 使用await 有效的

总结


前言

在JavaScript的`forEach`方法中使用`await`是无效的,因为`forEach`方法不支持异步操作的等待。

  `forEach`是一个数组的遍历方法,它会对数组中的每个元素依次执行提供的回调函数。而在JavaScript中,`await`关键字只能在异步函数(`async`函数)中使用,用于等待一个Promise对象的解析结果。

在`forEach`的回调函数中使用`await`关键字,实际上会导致它被忽略,无法正确地等待异步操作的完成。这是因为`forEach`不会等待回调函数中的异步操作完成,而是立即执行下一个回调函数。

  如果你需要在数组的每个元素上执行异步操作,并等待每个操作完成,可以考虑使用`for...of`循环结合`await`关键字,或者使用`map`方法结合`Promise.all`方法来处理异步操作。

Promise.all() 方法不能保证 Promise 对象的执行顺序,它只能确保所有的 Promise 对象都被解析后才会触发后续的处理。

虽然 Promise.all() 方法会等待所有的 Promise 对象都被解析,但它并不能保证上传操作的顺序。上传操作的顺序是可能会受到网络延迟等因素的影响,导致后续的处理可能会在某些上传操作完成之前就开始执行。 但是Promise.all()所以异步成功后返回的数组是对应关系

如果你希望确保上传操作按照数组中的顺序执行,可以考虑使用 for...of 循环,并等待每个上传操作完成后再处理下一个元素。

 注意:

  1. for:要使用在async异步方法里,循环会等await执行而停留,await是有效的,有break
  2. forEach:没有break,循环不会等await执行而停留,await是无效的;
  3. for of:要使用在async异步方法里,执行期间,await之前的代码会执行,到了await会等待await执行完才继续往下执行,有break
  4. for await of:也要用在async异步方法里,有break,但是它一般是使用在item是个异步方法的情况下,并不常见,场景如下面对应的例子,要遍历的数组元素是个异步请求,异步没回来之前整个for循环代码不执行。

for使用await -- 有效的

<script>
    let arr = ["我", "爱", "编", "程"]
    function getDatas(e) {
        return axios.get(`https://api.oioweb.cn/api/txt/dict?text=${e}`)
    }
    async function execute() {
        for (let i = 0; i < arr.length; i++) {
            console.log(`第${i + 1}次${arr[i]}执行了`)
            let datas = await getDatas(arr[i])
            console.log("返回结果:" + datas.data.result.words)
            console.log(`第${i + 1}次${arr[i]}执行完了`)
            console.log("---------end--------------")
        }
    }
    execute()

</script>

forEach使用await --  无效的

<script>
    let arr = ["我", "爱", "编", "程"]
    function getDatas(e) {
        return axios.get(`https://api.oioweb.cn/api/txt/dict?text=${e}`)
    }
    async function execute() {
        arr.forEach(async (item, index) => {
            console.log(`第${index + 1}次${item}执行了`)
            let datas = await getDatas(item)
            console.log("返回结果:" + datas.data.result.words)
            console.log(`第${index}次${item}执行完了`)
            console.log("---------end--------------")
        })
    }
    execute()

</script>

可以看到forEach中使用await是无效的,只不过await后面的代码能按顺序执行;

for of 使用await 有效的

<script>
    let arr = ["我", "爱", "编", "程"]
    function getDatas(e) {
        return axios.get(`https://api.oioweb.cn/api/txt/dict?text=${e}`)
    }
    async function execute() {
        let index = 0
        for (const item of arr) {
            console.log(`第${index + 1}次${item}执行了`)
            let datas = await getDatas(item)
            console.log("返回结果:" + datas.data.result.words)
            console.log(`第${index + 1}次${item}执行完了`)
            console.log("---------end--------------")
            index += 1
        }

    }
    execute()

</script>

for await of 使用await 有效的

<script>

    function getDatas(e) {
        return axios.get(`https://api.oioweb.cn/api/txt/dict?text=${e}`)
    }
    let arr = [getDatas("我"), getDatas("爱"), getDatas("编"), getDatas("程")]
    async function execute() {
        let index = 0
        for await (const item of arr) {
            console.log(`第${index + 1}次,方法${index + 1}执行了`)

            console.log("返回结果:" + item.data.result.words)
            console.log(`第${index + 1}次方法${index + 1}执行完了`)
            console.log("---------end--------------")
            index += 1
        }

    }
    execute()

</script>

总结

  • 实际开发中我们可以发现其实forwhilefor infor offor await of使用await都是生效的;
  • 而几乎有回调的遍历方法:forEachmapfilterreducesomeeveryfind等,使用await都是不生效的;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/348793.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

如何修改hosts文件-mac

1、什么是hosts文件&#xff1f; Hosts是一个没有扩展名的系统文件&#xff0c;可以用记事本等工具打开&#xff0c;其作用就是将一些常用的网址域名与其对应的IP地址建立一个关联“数据库”&#xff0c;即域名映射到IP地址&#xff0c;域名是为了方便人类记忆识别&#xff0c…

力扣354. 俄罗斯套娃信封问题

动态规划 思路&#xff1a; 同时控制 w、h 两个维度比较复杂&#xff0c;可以先固定一个维度&#xff0c;来找出另外一个维度的严格单调序列&#xff1a; 对 w 排序&#xff0c;然后再来找 h 维度严格单调递增序列长度&#xff1b;在 w 排序时&#xff0c;会遇到 w(i) w(j) 的…

VS2022联合Qt5开发学习11(QT5.12.3联合VTK在VS2022上开发医学图像项目5——qvtkWidget上显示STL三维图像并取点)

这篇博文是接着这个系列前面的博文&#xff0c;来讲如何实现医学图像三视图同步视图。我想到的一个思路是用Scrollbar来控制切面的改变&#xff0c;还有一个想法是在三维图像上取点&#xff0c;然后以这个点为切面中心更新三维视图。这篇博文主要介绍的就是第二个想法的三维图像…

C++ 之LeetCode刷题记录(十八)

&#x1f604;&#x1f60a;&#x1f606;&#x1f603;&#x1f604;&#x1f60a;&#x1f606;&#x1f603; 开始cpp刷题之旅。 依旧是追求耗时0s的一天。 104. 二叉树的最大深度 给定一个二叉树 root &#xff0c;返回其最大深度。 二叉树的 最大深度 是指从根节点到最…

防火墙源NAT配置

拓扑 需求 生产区在工作时间内可以访问服务器区&#xff0c;仅可以访问HTTP服务器。办公区全天可以访问服务区&#xff0c;其中&#xff0c;10.0.2.20可以访问FTP服务器和HTTP服务器 10.0.2.10仅可以ping通10.0.3.10办公区在访问服务区时采用匿名认证方式进行上网行为管理。办…

蓝桥杯备战——2.矩阵键盘

1.分析原理图 由上图可以看到若J5跳线帽接地&#xff0c;就S4~S7就可以当做四路独立按键&#xff0c;若接到P44&#xff0c;则就是4*4的矩阵键盘。 2.独立按键处理 相对传统的按键延时消抖方案&#xff0c;这里我采用更高效&#xff0c;更经典&#xff0c;更偏向产品级应用的…

JavaScript DOM之Cookie详解

cookie有的地方习惯使用复数形式的cookies&#xff0c;指的是网站为了识别用户的身份或者进行一些必要数据的缓存而使用的技术&#xff0c;它的数据是存在用户的终端上&#xff0c;也就是在浏览器上的。 一、什么是cookie 随着互联网的不断发展各种基于互联网的服务系统逐渐多…

第139期 做大还是做小-Oracle名称哪些事(20240125)

数据库管理139期 2024-01-25 第139期 做大还是做小-Oracle名称哪些事&#xff08;20240125&#xff09;1 问题2 排查3 扩展总结 第139期 做大还是做小-Oracle名称哪些事&#xff08;20240125&#xff09; 作者&#xff1a;胖头鱼的鱼缸&#xff08;尹海文&#xff09; Oracle A…

【C#】基础巩固

最近写代码的时候各种灵感勃发&#xff0c;有了灵感&#xff0c;就该实现了&#xff0c;可是&#xff0c;实现起来有些不流畅&#xff0c;总是有这样&#xff0c;那样的卡壳&#xff0c;总结下来发现了几个问题。 1、C#基础内容不是特别牢靠&#xff0c;理解的不到位&#xff…

2016年认证杯SPSSPRO杯数学建模B题(第一阶段)低分辨率下看世界全过程文档及程序

2016年认证杯SPSSPRO杯数学建模 B题 低分辨率下看世界 原题再现&#xff1a; 数码摄像技术被广泛使用于多种场合中。有时由于客观条件的限制&#xff0c;拍摄设备只能在较低的分辨率下成像。为简单起见&#xff0c;我们只考虑单色成像。假设成像的分辨率为 32 64&#xff0c…

架构师之路(十四)计算机网络(网络层)

前置知识&#xff08;了解&#xff09;&#xff1a;计算机基础。 作为架构师&#xff0c;我们所设计的系统很少为单机系统&#xff0c;因此有必要了解计算机和计算机之间是怎么联系的。局域网的集群和混合云的网络有啥区别。系统交互的时候网络会存在什么瓶颈。 网络层提供主机…

Dlearning

Deep Learning Basic 神经网络&#xff1a; #mermaid-svg-rR22a8Udy5SxGOoP {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-rR22a8Udy5SxGOoP .error-icon{fill:#552222;}#mermaid-svg-rR22a8Udy5SxGOoP .error-t…

线扫相机使用教程

一.线扫相机的采集原理 在现有的工业 2D 相机中&#xff0c;主要有两种类型的相机&#xff0c;面阵相机和线扫相机。这两种相机有其 各自的特点。 面阵相机&#xff1a;主要用于采集较小尺寸的产品&#xff0c;特别是长度方向较小的产品。其采集原理是通过 单次或多次曝光&…

Atlassian 停服 Bitbucket?三步快速迁移至极狐GitLab

之前的文章Jira 母公司全面停服 Server 产品&#xff0c;用户如何迁移至极狐GitLab提到了 Atlassian 将在 2 月 15 日以后停止对 Server 端产品的服务支持&#xff0c;此后用户将无法像之前一样继续使用 Jira、Bitbucket、Bamboo、Confluence 这些产品了。如果用户想要继续使用…

蓝牙----蓝牙消息传输_GATT服务发现

蓝牙消息传输_GATT服务发现 1.主机和从机GATT服务的发现2.通知的使用 1.主机和从机GATT服务的发现 GATT服务的发现由主机执行&#xff0c;一共三个阶段  1.处理交换 MTU 请求和响应&#xff0c;启动对 Simple Service 服务的发现。 if (discState BLE_DISC_STATE_MTU){// MT…

四川思维跳动商务信息咨询有限公司专注抖音电商服务

在当今这个数字化时代&#xff0c;电商服务已经成为企业发展的重要驱动力。四川思维跳动商务信息咨询有限公司作为一家专注于抖音电商服务的公司&#xff0c;以其卓越的服务质量和创新能力&#xff0c;成为了行业的领航者。 四川思维跳动商务信息咨询有限公司自成立以来&#x…

pyqt5+vscode 配置坑笔记

1.conda activate XX 时失败 这样出来的python版本也是错的&#xff08;总是全局版本&#xff09; 无法加载文件 D:\Documents\WindowsPowerShell\profile.ps1&#xff0c;因为在此系统上禁止运行脚本 系统设置允许执行脚本解决 无法加载文件WindowsPowerShell\profile.ps1…

leetcode hot100组合

在本题中&#xff0c;是要求返回[1,n]这个数组的长度为k的组合。涉及到排列、组合、棋盘、分割等问题的时候&#xff0c;要考虑利用回溯来进行解决。 回溯和递归类似&#xff0c;也分为三步进行分析 确定递归函数的返回值和参数&#xff1a;一般来说返回值都是void&#xff0c…

互斥锁/读写锁(Linux)

一、互斥锁 临界资源概念&#xff1a; 不能同时访问的资源&#xff0c;比如写文件&#xff0c;只能由一个线程写&#xff0c;同时写会写乱。 比如外设打印机&#xff0c;打印的时候只能由一个程序使用。 外设基本上都是不能共享的资源。 生活中比如卫生间&#xff0c;同一…

微软人工智能办公AI工具 Copilot Pro 11项 Copilot 功能

Copilot&#xff08;曾用名 Bing Chat 和 Bing Chat Enterprise&#xff09;在此期间成为了许多用户的日常AI伴侣&#xff0c;并在正式发布后将继续为用户提供AI驱动的网络聊天体验。 微软Copilot官方网址链接&#xff1a;Microsoft Copilot: 你的日常 AI 助手 Copilot详情&am…