【因为实现不了Promise.all,一场面试凉凉了】不飞则已,一飞冲天;不鸣则已,一鸣惊人。这篇文章主要讲述因为实现不了Promise.all,一场面试凉凉了相关的知识,希望能为你提供帮助。
前言(?﹏?)曾经真实发生在一个朋友身上的真实事件,面试官让他手写一个??Promise.all?
?,朋友现场发挥不太好,没有写出来,事后他追问面试官给的模糊评价是基础不够扎实,原理性知识掌握较少... 当然整场面试失利,并不仅仅是这一个题目,肯定还有其他方面的原因。
但是却给我们敲响一个警钟:??Promise手写实现?
??、??Promise静态方法实现?
?早已经是面试中的高频考题,如果你对其还不甚了解,耽误你10分钟,我们一起干到他懂O(∩_∩)O
常见面试手写系列
??1. 点击查看日拱一题源码地址(目前已有66+个手写题实现)??
??胖头鱼?
??最近很想做一件事情,希望可以将前端面试中??常见的手写题?
??写成一个系列,尝试将其中涉及到的知识和原理都讲清楚,如果你对这个系列也感兴趣,欢迎一起来学习噢,目前已有??66+手写题?
?实现啦!
Promise.resolve简要回顾
- ?
?Promise.resolve(value) ?
?方法返回一个以给定值解析后的??Promise?? 对象。 - 如果这个值是一个 promise ,那么将返回这个 promise ;
- 如果这个值是thenable(即带有??"then" ??方法),返回的promise会“跟随”这个thenable的对象,采用它的最终状态;否则返回的promise将以此值完成。
- ?
?Promise.resolve?
?最终结果还是一个??Promise?
?,并且与??Promise.resolve(该值)?
?传入的值息息相关 - 传入的参数可以是一个?
?Promise实例?
?,那么该函数执行的结果是直接将实例返回 - 这里最主要需要理解跟随,可以理解成?
?Promise最终状态?
?就是这个thenable对象输出的值
// 1. 非Promise对象,非thenable对象
Promise.resolve(1).then(console.log) // 1
// 2. Promise对象成功状态
const p2 = new Promise((resolve) => resolve(2))
Promise.resolve(p2).then(console.log) // 2
// 3. Promise对象失败状态
const p3 = new Promise((_, reject) => reject(err3))
Promise.resolve(p3).catch(console.error) // err3
// 4. thenable对象
const p4 =
then (resolve)
setTimeout(() => resolve(4), 1000)
Promise.resolve(p4).then(console.log) // 4
// 5. 啥都没传
Promise.resolve().then(console.log) // undefined
源码实现
Promise.myResolve = function (value)
// 是Promise实例,直接返回即可
if (value & & typeof value =https://www.songbingjia.com/android/== object & & (value instanceof Promise))
return value
// 否则其他情况一律再通过Promise包装一下
return new Promise((resolve) =>
resolve(value)
)
// 测试一下,还是用刚才的例子
// 1. 非Promise对象,非thenable对象
Promise.myResolve(1).then(console.log) // 1
// 2. Promise对象成功状态
const p2 = new Promise((resolve) => resolve(2))
Promise.myResolve(p2).then(console.log) // 2
// 3. Promise对象失败状态
const p3 = new Promise((_, reject) => reject(err3))
Promise.myResolve(p3).catch(console.error) // err3
// 4. thenable对象
const p4 =
then (resolve)
setTimeout(() => resolve(4), 1000)
Promise.myResolve(p4).then(console.log) // 4
// 5. 啥都没传
Promise.myResolve().then(console.log) // undefined
疑问
从源码实现中,并没有看到对于?
?thenable?
??对象的特殊处理呀!其实确实也不需要在??Promise.resolve?
??中处理,真实处理的地方应该是在??Promise?
??构造函数中,如果你对这块感兴趣,马上就会写??Promise?
?的实现篇,期待你的阅读噢。Promise.reject简要回顾
??Promise.reject() ?
??方法返回一个带有拒绝原因的??Promise?
?对象。
Promise.reject(new Error(fail))
.then(() => console.log(Resolved),
(err) => console.log(Rejected, err))
// 输出以下内容
// Rejected Error: fail
//at < anonymous> :2:16
源码实现
reject实现相对简单,只要返回一个新的Promise,并且将结果状态设置为拒绝就可以
Promise.myReject = function (value)
return new Promise((_, reject) =>
reject(value)
)
// 测试一下
Promise.myReject(new Error(fail))
.then(() => console.log(Resolved),
(err) => console.log(Rejected, err))
// Rejected Error: fail
//at < anonymous> :9:18
Promise.all简要回顾
??Promise.all()?
?方法用于将多个 Promise 实例,包装成一个新的 Promise 实例。这个静态方法应该是面试中最常见的啦
const p = Promise.all([p1, p2, p3])
最终?
?p?
??的状态由??p1?
??、??p2?
??、??p3?
?决定,分成两种情况。(1)只有?
?p1?
??、??p2?
??、??p3?
??的状态都变成??fulfilled?
??,??p?
??的状态才会变成??fulfilled?
??,此时??p1?
??、??p2?
??、??p3?
??的返回值组成一个数组,传递给??p?
?的回调函数。(2)只要?
?p1?
??、??p2?
??、??p3?
??之中有一个被??rejected?
??,??p?
??的状态就变成??rejected?
??,此时第一个被??reject?
??的实例的返回值,会传递给??p?
?的回调函数。const p1 = Promise.resolve(1)
const p2 = new Promise((resolve) =>
setTimeout(() => resolve(2), 1000)
)
const p3 = new Promise((resolve) =>
setTimeout(() => resolve(3), 3000)
)
const p4 = Promise.reject(err4)
const p5 = Promise.reject(err5)
推荐阅读
- RocketMQ集群部署
- 有奖调研 | 即时消息服务的产品需求规划就交给你了!
- 面试官问你 JVM,你知道加分项在哪吗()
- 一行Python代码,给PDF文件添加水印,快速而且免费~python-office自动化办公,YYDS
- Sublime快捷键设置
- C#/VB.NET 合并PDF页面
- 二进制部署etcd高可用集群
- Kubernetes的pod调度
- Es数据采集工具之filebeat安装和使用