Promise源码解密-Promise A+标准,腾讯最爱考的前端面试题

const STATUS_PENDING = “pending”;

const STATUS_FULFILLED = “fulfilled”;

const STATUS_REJECTED = “rejected”;

class Promise {

constructor(executor) {

this.status = STATUS_PENDING;

}

}

1.1. 等待(Pending)

处于等待时,状态可以迁移至执行态或拒绝态

1.2. 执行(Fulfilled)

处于执行时:

  • 不能迁移至其他任何状态

  • 必须拥有一个不可变的终值

1.3. 拒绝(Rejected)

处于拒绝时:

  • 不能迁移至其他任何状态

  • 必须拥有一个不可变的reason

这里的不可变指的是恒等(即可用 === 判断相等),引用数据类型只要保证地址相等即可。

new Promise((resolve, reject) => {

resolve(‘成功’);

reject(‘拒绝’)

}).then((res) => {

console.log(res,“res”)

}, (error) => {

console.log(error,‘reason’)

})

new Promise()时状态是pending,

当程序执行,也就是(resolve, reject) => {

resolve(‘成功’);

reject(‘拒绝’)

},这个执行

这里resolve把值进行了this.value = “成功”;,但是并不会this.reason=‘拒绝’,

这是因为只有出现了执行就不会出现拒绝,最后输出的结果是"成功 res",

如果注释掉resolve(‘成功’);,最后输出的结果是 “拒绝 reason”。

2. Then 方法

一个 promise 必须提供一个 then 方法以访问其当前值、终值 和 reason。

promise 的 then 方法接受两个函数参数:

promise.then(onFulfilled, onRejected)

then((res) => {

console.log(res,“res”)

}, (error) => {

console.log(error,‘reason’)

})

2.1 onFulfilledonRejected 都是可选参数。
  • 如果 onFulfilled 不是函数,必须被忽略

  • 如果 onRejected 不是函数,必须被忽略

2.2 onFulfilled

如果 onFulfilled 是函数:

  • promise 执行结束后其必须被调用,其第一个参数为 promise的value

  • promise 执行结束前其不可被调用

  • 其调用次数不可超过一次

new Promise((resolve, reject) => {

resolve(123)

}).then(result => {

console.log(result);

}, error => {

console.log(error);

});

// 这里resolve执行结束才会执行then,这里的result就是终值

2.3 onRejected

如果 onRejected 是函数:

  • promise 被拒绝执行后其必须被调用,其第一个参数为 promise 的reason

  • promise 被拒绝执行前其不可被调用

  • 其调用次数不可超过一次

2.4 调用时机

onFulfilledonRejected 只有在执行环境堆栈仅包含平台代码时才可被调用 >> 注1

2.5 调用要求

onFulfilledonRejected 必须被作为函数调用(即没有 this 值)>> 注2

2.6 多次调用

then方法可以被同一个promise 调用多次

  • promise 成功执行时,所有 onFulfilled 需按照其注册顺序依次回调

  • promise 被拒绝执行时,所有的 onRejected 需按照其注册顺序依次回调

new Promise.then().then()

2.7 返回

then 方法必须返回一个 promise 对象 >> 注3, 这也就是then可以被多次调用的原因。

Promise.prototype.then=function(onFulfilled, onRejected){

return new Promise()

}

promise2 = promise1.then(onFulfilled, onRejected);

  • 如果 onFulfilled 或者 onRejected 返回一个值 x ,则运行下面的 Promise 解决过程[[Resolve]](promise2, x)

promise1.then((value)=>{

return x;

}, (reason)=>{

return x

}),

// 这种情况需要处理x函数还是值还是其他情况 ,所有用到了 Promise 解决过程

// 这种情况直接

Promise.prototype.then=function(onFulfilled, onRejected){

return let promise2 = new Promise((resolve,reject)=>{

try {

let x = onFulfilled(this.value);

resolvePromise(promise2, x, resolve, reject);

} catch (e) {

reject(e);

}

})

}

  • 如果 onFulfilled 或者 onRejected 抛出一个异常 e ,则 promise2 必须拒绝执行,并返回拒因 e

promise1.then((value)=>{

throw new Error()

}, (reason)=>{

throw new Error()

}),

// 这种情况直接

Promise.prototype.then=function(onFulfilled, onRejected){

return new Promise((resolve,reject)=>{

try {

// console.log(“执行 onFulfilled”);

// 这里的x是啥? 是then中回调的return的返回值

onFulfilled(this.value);

或者

onReject(this.reason)

} catch (e) {

reject(e);

}

})

}

  • 如果 onFulfilled 不是函数且 promise1 成功执行, promise2 必须成功执行并返回相同的值

promise1.then(1,2),

Promise.prototype.then=function(onFulfilled, onRejected){

if (this.status === STATUS_FULFILLED) {

return new Promise((resolve,reject)=>{

if(typeof onFulfilled !== “function” ){

resolve(onFulfilled)

}

if(typeof onRejected !== “function” ){

resolve(onRejected)

}

})

}

}

  • 如果 onRejected 不是函数且 promise1 拒绝执行, promise2 必须拒绝执行并返回相同的reason

promise1.then(1,2),

Promise.prototype.then=function(onFulfilled, onRejected){

if (this.status === STATUS_PENDING) {

return new Promise((resolve,reject)=>{

reject(onRejected)

})

}

}

Promise 解决过程


Promise 解决过程是需要输入一个 promise 和一个值 x 的一个抽象的操作,称为 [[Resolve]](promise, x),如果 xthen 方法且看上去像一个 Promise ,解决程序即尝试使 promise 接受 x 的状态;否则其用 x 的值来执行 promise 。(x是返回值,请注意上面的例子)

解决过程步骤:

xpromise 相等

如果 promisex 指向同一对象,直接 throw new TypeError

let p1=new Promise(resolve=>{

resolve()

})

let p2=p1.then(data=>{

// 返回了p2

return p2

})

x 是Promise

如果 x 是一个 Promise ,则使 promise 接受 x 的状态 >>注4

  • 如果 x 处于等待, promise 需保持等待直至 x 被执行或拒绝

  • 如果 x 处于执行,用相同的值执行 promise

  • 如果 x 处于拒绝,用相同的reason拒绝 promise

x 为对象或函数

如果 x 为对象或者函数:

  • x.then 赋值给 then>> 注5

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:前端)

最后

整理面试题,不是让大家去只刷面试题,而是熟悉目前实际面试中常见的考察方式和知识点,做到心中有数,也可以用来自查及完善知识体系。

《前端基础面试题》,《前端校招面试题精编解析大全》,《前端面试题宝典》,《前端面试题:常用算法》PDF完整版点击这里免费领取

前端面试题宝典

前端校招面试题详解

5%以上前端开发知识点,真正体系化!**

[外链图片转存中…(img-6oU9eC0b-1712199128794)]

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:前端)

最后

整理面试题,不是让大家去只刷面试题,而是熟悉目前实际面试中常见的考察方式和知识点,做到心中有数,也可以用来自查及完善知识体系。

《前端基础面试题》,《前端校招面试题精编解析大全》,《前端面试题宝典》,《前端面试题:常用算法》PDF完整版点击这里免费领取

[外链图片转存中…(img-FCOM8KuA-1712199128795)]

[外链图片转存中…(img-Kod11wxp-1712199128795)]

[外链图片转存中…(img-w6FyAeIN-1712199128795)]

  • 7
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值