博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
掌握 Promise 的逻辑方法
阅读量:4118 次
发布时间:2019-05-25

本文共 2519 字,大约阅读时间需要 8 分钟。

来源 | https://www.cnblogs.com/xyzhanjiang/archive/2020/12/05/14090357.html

Promise 是 ES2015 新增的对象

Promise 对象有几个组合方法,可以将多个承诺合并成一个进行处理

分别是 Promise.all, Promise.race, Promise.allSettled, Promise.any

这些方法都可以接收一组承诺,返回一个新的承诺

Promise.all(values)

其中参数 values 是一个可迭代对象,比如数组

在后文中使用词语“成功”表示承诺 resolve,“失败”表示承诺 reject

Promise.all

Promise.all 方法返回的承诺会等到参数中所有的承诺都成功之后才会成功,只要其中有一个失败了则返回的承诺也会立即失败,不会等到那些还挂起的承诺有结果

Promise.all 方法可以用来处理那些缺一不可的逻辑

示例:同时发出多个请求都成功后才能进行下一步

const coffee = fetch('/coffee')const tea = fetch('/tea')const me = fetch('/me')// 我全都要const res = await Promise.all([coffee, tea, me])

Promise.race

Promise.race 方法返回参数中最快的那个承诺,如果最快的那个承诺成功则返回的承诺也会成功,否则就是失败,不会等到那些还挂起的承诺有结果

示例:给一个复杂任务设定一个超时时间

// 设置一个定时器,时间到了就 reject 一个承诺const timeout = new Promise((resolve, reject) => {  setTimeout(reject, 3000)})const missions = fetch('/missions')try {  const res = await Promise.race([timeout, missions])  // missions 任务成功} catch () {  // 时间超过 3 秒了或者任务失败了}

Promise.allSettled

Promise.allSettled 方法返回的承诺对象会等到参数中所有的承诺对象都完成后才成功,无论怎样该方法返回的承诺都不会失败

和 Promise.all 方法的区别

Promise.all 方法需要参数中的所有承诺都成功

而 Promise.allSettled 对参数中的承诺是成功还是失败并不关心,只要有结果就行

示例:一次性上传多个文件,其中上传成功和上传失败的互不影响,在一轮上传任务完成之后,可以筛选出那些上传失败的重新上传。

const upload = file => {  const formData = new FormData()  formData.append('file', file)  return fetch('/upload', {    method: 'POST',    body: formData  })}document.querySelector('input[type="file"]').addEventListener('change', function(e) {  if (!e.target.value) return  const files = e.target.files  const promises = files.map(file => upload(file))  const res = await Promise.allSettled(promises)  // 全部上传任务都完成了,找出上传失败的重新上传})

该方法是 ES2020 新添加的方法

Promise.any

Promise.any 方法返回一组承诺中最快成功的那个承诺,如果参数中所有承诺都失败了,那么返回的承诺也失败

和 Promise.race 方法的区别

Promise.race 返回参数中最快的那个承诺,无论它是成功还是失败

而 Promise.any 关注的是参数中最快同时还必须成功的那个承诺

和 Promise.all 方法的区别

Promise.any 和 Promise.all 是完全相反的

Promise.any 参数中全部承诺都失败了才会失败,Promise.all 参数中全部承诺都成功了才会成功

Promise.any 参数中一旦有一个承诺成功了返回的新承诺就会成功,Promise.all 参数中一旦有一个承诺失败了返回的新承诺就会失败

示例:同时加载一组图片,但是我们只需要用到其中的一张,就可以用 Promise.any 方法挑选出最先加载成功的那张图片

const fetchImg = async (url) => {  return fetch(url).then(res => {    if (!res.ok) {      throw new Error('HTTP error!')    } else {      return res.blob()    }  })}cosnt img1 = fetchImg('/1.png')const img2 = fetchImg('/2.png')try {  const res = await Promise.any([img1, img2])  const url = URL.createObjectURL(res)  const img = document.createElement('img')  img.src = url  document.body.appendChild(img)} catch () {  // 一个都没加载成功 QAQ}

该方法还处于草案中,目前最新的 Chrome, Firefox, Safari 支持。

本文完~

你可能感兴趣的文章
不错的一款基于CSS 3的按钮动画库Animate.css
查看>>
自驾跑高速必看!
查看>>
基于Java的CSV格式文件处理(excel逗号分隔符文件)
查看>>
Mac OS系统与对应支持的XCode及SDK版本
查看>>
CSDN精选iPhone开发博客
查看>>
CSDN精选Android开发博客
查看>>
又走过了一年
查看>>
JavaEE应用程序性能调优案例分析
查看>>
图形图像技术专业培养方案(参考)
查看>>
读三国志有感之一·时机
查看>>
认识苹果电脑的必备常识
查看>>
读三国志有感之二·好学知礼的倔老头儿
查看>>
史上最牛SQL注入
查看>>
这个寒假收获颇丰
查看>>
最近接触了几个90后准程序员
查看>>
关于职业教育
查看>>
电子警察位置【收藏】
查看>>
Nginx+Tomcat 动静分离实现负载均衡
查看>>
Visual Studio 2010 Download
查看>>
Eclipse快捷键【收藏】
查看>>