TypechoJoeTheme

至尊技术网

统计
登录
用户名
密码
搜索到 2 篇与 的结果
2025-11-14

手写Promise核心原理及源码实现

手写Promise核心原理及源码实现
在现代JavaScript开发中,Promise已经成为处理异步操作的基石。无论是网络请求、定时器回调,还是复杂的异步流程控制,我们都离不开它的身影。然而,很多开发者只是“会用”Promise,却对其内部机制一知半解。本文将带你从零开始,深入剖析Promise的核心原理,并手写一个符合规范的简易Promise实现。Promise的本质:状态机与回调管理Promise本质上是一个状态机,它有三种状态:pending(等待)、fulfilled(成功)和rejected(失败)。一旦状态从pending变为fulfilled或rejected,就不可逆,这保证了Promise的确定性。当我们调用new Promise(executor)时,传入的executor函数会立即执行。这个函数接收两个参数:resolve和reject,用于改变Promise的状态。例如:js const p = new Promise((resolve, reject) => { setTimeout(() => { resolve('success'); }, 1000); }...
2025年11月14日
1 阅读
0 评论
2025-08-07

Promise中的then方法详解:异步编程的核心机制

Promise中的then方法详解:异步编程的核心机制
一、then方法的本质与基础用法Promise的then方法是连接同步世界与异步世界的桥梁。当我们需要在异步操作完成后执行特定逻辑时,then方法提供了声明式的处理入口:javascript fetch('/api/data') .then(response => response.json()) .then(data => console.log(data))其基本语法包含两个参数: - onFulfilled:Promise状态变为fulfilled时执行 - onRejected:Promise状态变为rejected时执行(建议使用catch方法替代)关键特性: 1. 微任务调度:then回调会被放入微任务队列,在当前宏任务完成后执行 2. 返回值决定链式状态:回调函数的返回值会影响后续Promise链的状态 3. 值穿透机制:当未提供处理函数时,值会直接传递到下一个then二、链式调用的实现原理then方法最强大的特性在于其链式调用能力,这得益于以下设计:javascript new Promise(resolve => resolve(1))...
2025年08月07日
53 阅读
0 评论

人生倒计时

今日已经过去小时
这周已经过去
本月已经过去
今年已经过去个月

最新回复

  1. 强强强
    2025-04-07
  2. jesse
    2025-01-16
  3. sowxkkxwwk
    2024-11-20
  4. zpzscldkea
    2024-11-20
  5. bruvoaaiju
    2024-11-14

标签云