当前位置: 首页 > news >正文

网站建设 设计提成广告公司推广

网站建设 设计提成,广告公司推广,做网站的分辨率多少,清河网站建设前言这个问题是这样产生的?某天,在学习异步的知识遇到这样一道题:使用Promise的方式,每隔一秒输出数组中一个值const arr [1, 2, 3] ​ arr.reduce((pre, cur) > {return pre.then(() > {returnnewPromise((resolve, rejec…

前言

这个问题是这样产生的?某天,在学习异步的知识遇到这样一道题:使用Promise的方式,每隔一秒输出数组中一个值

const arr = [1, 2, 3]
​
arr.reduce((pre, cur) => {return pre.then(() => {returnnewPromise((resolve, reject) => {setTimeout(() => {resolve(console.log(cur))}, 1000);})})
}, Promise.resolve())
复制代码

那这段代码还是挺好了解的,相当于

Promise.resolve().then(() => {returnnewPromise((resolve, reject) => {setTimeout(() => {resolve(console.log(1))}, 1000);})
}).then(() => {returnnewPromise((resolve, reject) => {setTimeout(() => {resolve(console.log(2))}, 1000);})
}).then(() => {returnnewPromise((resolve, reject) => {setTimeout(() => {resolve(console.log(3))}, 1000);})
})
复制代码

看完之后,我就在想,如果我在循环中,每次输出值之后停止一秒,也可以解决,于是乎就有了以下代码

const arr = [1, 2, 3]
​
constsleep = (ms) => {returnnewPromise((resolve, reject) => {setTimeout(() => {resolve()}, ms)})
}
​
for (let i = 0; i < arr.length; i++) {console.log(arr[i]);awaitsleep(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]constsleep = (ms) => {returnnewPromise((resolve, reject) => {setTimeout(() => {resolve()}, ms)})}constlogByOneSecond = async () => {for (let i = 0; i < arr.length; i++) {console.log(arr[i]);awaitsleep(1000)}}   logByOneSecond()</script>   
复制代码

所以这就算闹了个笑话,哈哈,不过当我遇到不理解的时候,又多了一个思考方向。

好的,如上所述,await确实发挥了他的作用,让JS直到等到了promise返回的处理结果,再继续往下执行;那for...of,while是不是也可以呢

const logByForof = async () => {for (const item of arr) {console.log(item);await sleep(1000)}    
}
logByForof()
复制代码
constlogByWhile = async () => {let i = 0while (i !== arr.length) {awaitsleep(1000)console.log(arr[i]);i++}
}
logByWhile()
复制代码

结果也是符合预期,可以在循环中使用await并实现效果

在forEach循环中的await

如一开始,在forEach中并没有的到预期的效果;首先得到一个结果:forEach中async 和await是无效的。

那我看到的解释有以下几种

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

  1. map/forEach内部使用了while结合callback方式来执行函数,await不会等待callback的执行

  1. 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 了。

大厂面试题分享 面试题库

前端后端面试题库 (面试必备) 推荐:★★★★★

地址:前端面试题库

http://www.mmbaike.com/news/64589.html

相关文章:

  • 本地的上海网站建设网站推广的常用方法
  • 做a短视频网站怎样做好竞价推广
  • 做网站从哪里买域名市场营销推广策略
  • 网站ftp文件百度投放广告
  • 网站建设方案网络营销是什么专业类别
  • 湖南网站建设哪家专业手机百度下载安装
  • cdn 动态网站 加速张北网站seo
  • wordpress docseo外包公司多吗
  • 杭州设计 公司 网站百度指数在哪里看
  • 网站优化推广seo怎么开发网站
  • 网站出现风险如何处理芭嘞seo
  • crm免费永久使用北京网站优化策略
  • 如何把网站做的好看网络营销的目标
  • 长春做网站设计黄页网站推广公司
  • 找建设项目的网站营销课程培训都有哪些
  • wordpress手机站h5优化开发一个小程序一般需要多少钱呢
  • 买域名去哪个网站刷关键词排名seo软件软件
  • 淄博政府做网站哪家好如何建立网上销售平台
  • CSS3网站开发最新疫情19个城市封城
  • 网站服务器托管哪个平台推广效果好
  • 保定 营销型网站建设南宁seo做法哪家好
  • 网站与客户端的区别吗山西疫情最新情况
  • 湛江宇锋网站建设嘉兴seo网络推广
  • 用户界面设计与制作南宁网站seo
  • 回龙观手机网站开发服务外贸软件
  • 成都住建局官网站首页广东省各城市疫情搜索高峰进度
  • 做网站干嘛百度网讯科技有限公司官网
  • 怎么制作自己的微信小程序湘潭seo优化
  • 网站个性化网站优化排名方法有哪些
  • 免费网站建设哪个好免费做做网站