【手写 Promise 源码】目录 - Promise 知识点梳理
创始人
2024-05-17 08:11:38

一,前言

目前,以下专栏已完结(初版完结,持续重构中):

  • 《手写 Vue2 源码》
  • 《手写 VueRouter 源码》
  • 《手写 Vuex 源码》
  • 《Java 设计模式》

在此,要感谢大家的支持、鼓励和认可,以及大家所提出的宝贵建议,这也是我持续输出的动力之一,内容上还有很多不足还希望大家能够谅解;

从本篇开始,进入【手写 Promise 源码】,对相关知识点进行梳理和总结;


二,Promise 概述

写这个专栏的初衷,更多还是做个人知识的梳理和总结,主要会集中在以下两个部分:

  • 分析和解决开发中的异步问题,思考如何写出更为优雅的代码;
  • 了解Promise原理,学习Promise A+规范,并从0 ~ 1实现一个Promise库;

Promise的重要性;

  • Promise在前端领域拥有绝对的地位,面试核心考察点;
  • 框架和库的应用广泛:一些核心的设计思想也在众多框架中都有应用;
  • Promise的实现中,高阶函数、柯里化思想、发布订阅模式都有所体现;

本篇,将对Promise相关知识点进行梳理和拆分;


三,Promise 知识点梳理(专栏目录)

备注:内容链接会随文章发布同步更新,初版共 18 篇,目前更新 2 篇,每日更新 2 篇;

主题
知识点
1,Promise 简介Promise 简介和基本使用;
Promise 和 callback 对比;
Promise 的重要性和作用;
Promise 使用场景:Promisify 封装;
Promise 的优缺点、兼容性;
2,Promise 功能介绍与特性分析Promise 基础特性;
Promise 实例 API(原型方法)的介绍和使用;
Promise 静态 API(类方法)的介绍和使用;
3,实现一个简版 PromisePromise 的实现思路;
Promise A+ 规范(简版);
Promise 简版实现和功能测试;
4,翻译并理解 Promise A+ 规范对照 Promise A+ 规范英文版逐句进行翻译和理解
5,实现 Promise 异步操作测试 Promise 对异步操作的支持;
分析当前 Promise 代码问题及解决方案;
使用发布订阅思想实现对异步操作的支持;
Promise 异步操作的测试;
6,实现 Promise 链式调用介绍了 Promise 链式调用,返回普通值和抛出异常的5种情况;
分析了当前 Promise 源码的问题及解决方案;
Promise 链式调用的实现、功能测试、执行过程分析;
7,实现 Promise 返回值 x 的处理回顾了 Promise A+ 规范中的相关内容;
根据 Promise A+ 规范实现 resolvePromise 方法;
实现了对 then 中方法的返回值 x 为 promsie 类型的处理;
8,完善 Promise 并通过 promise-aplus-tests 测试支持 resolve(Promise)的情况;
支持 Promise 的 then 中方法返回 promise 后,继续 resolve(Promise)的情况;
Promise 的兼容处理;
分析了 Promise 的执行过程;
创建延迟对象并通过 promise-aplus-tests 测试;
9,Promise.resolve 和 Promise.reject 的实现实现 Promise 静态 API(类方法):Promise.resolve 和 Promise.reject;
10,Promise.prototype.catch 和 Promise.prototype.finally 的实现实现 Promise 实例 API(原型方法):Promise.prototype.catch 和 Promise.prototype.finally;
11,Promise.all 的实现测试原生 Promise.all 的使用;
Promise.all 的功能与特性分析;
Promise.all 的源码实现、执行分析、功能测试;
12,Promise.race 的实现测试原生 Promise.race 的使用;
Promise.race 的功能与特性分析;
Promise.race 的源码实现、执行分析、功能测试;
13,Promise.allsettled 和 Promise.any 的实现测试原生 Promise.allsettled 的使用;
Promise.allsettled 原理分析、源码实现、功能测试;
Promise.any 原理分析、源码实现、功能测试;
14,实现工具方法 promisifypromisify 简介和测试;
promisify 功能的实现:promisify、promisifyAll;
15,了解 generator 生成器generator生成器简介:特性、用法、功能分析;
generator生成器的实现原理分析;
16,了解 co 库co 库的简介:特性、用法、功能分析;
co 库的实现和原理分析;
17,async/await 简介async/await 的使用和功能分析;
async/await 的实现和原理分析;
18,EventLoop 简介EventLoop 简介;
宏任务和微任务;
EventLoop 循环机制;
19,Promise 面试题常见面试题分析
Promise 相关知识总结

暂时以表格中的主题作为参考,过程中会继续进行细化和扩展,如:穿透问题,不同场景下的使用分析,源码中的编程技巧和设计模式等;


四,结尾

本篇,对Promise相关知识点进行梳理和拆分;

作为Promise专栏目录,随文章更新会持续完善,欢迎大家留言讨论和补充;

下一篇,Promise的介绍和使用;


维护日志

  • 20211025
    • 更新专栏目录和链接;
  • 20211120
    • 更新专栏目录和链接;
  • 20211123
    • 更新专栏目录和链接;
    • 优化文章排版和部分描述;
  • 20230126
    • 优化表格标题与内容的对齐方式,更新表格内容链接;

相关内容

热门资讯

稳固百亿基本盘!全棉时代筑牢消... 2025年,在国际贸易摩擦加剧、关税壁垒抬升,行业整体压力不减的背景下,稳健医疗(300888.SZ...
伊朗称在霍尔木兹海峡上空击落美... 人民财讯5月7日电,伊朗方面消息称,伊朗防空部队当地时间5日晚在霍尔木兹海峡上空击落了一架美军无人机...
CPO 概念行情火热 产业扩容... 5 月 7 日全球宏观盘面重磅洗牌,美元持续弱势震荡、美股全线冲高刷新历史新高,有色金属迎来强势拉升...
媒体视点 | 从“赚了多少钱”... 当新质生产力积厚成势,成为引领中国经济高质量发展的强大新引擎,中国资本市场的科技叙事逻辑更加清晰和具...
告别传统赏花!在黄浦,这十二座... (来源:上观新闻)2026年的春天,上海的城市公共空间里绽放出一片与众不同的春日胜景。新天地绿地里造...