Promise实现

本文深入解析Promise的工作原理,从零开始实现一个简单的Promise函数。通过理解其内部状态转换机制及then方法的执行流程,帮助读者掌握Promise的核心概念。

实现一个简单的promise

首先promise是一种异步解决方案,避免了开发中的回调地狱的问题,promise状态有三种,pending resolved,rejected 一旦状态改变将不可逆,也就是说状态只能由pending——resolved或者pending——rejected,下面来实现一个简单的promise函数

function PromiseMy(constructor){
	var self = this;
	this.state = 'pending';
	this.value = undefined;
	this.msg = undefined;
	function resolve (value){
		if(self.state === 'pending'){
			self.state = 'resolved';
			self.value = value;
        }
	}
   function reject(value){
		if(self.state === 'pending'){
			self.state = 'rejected';
			self.msg = msg;
        }
	}
	try{
		constructor(resolve,reject)
	}catch(e){
		reject(e)
	}
}
在原型上编写then方法
PromiseMy.prototype.then = function(onResolved,onRejected){
    var selef = this;
	if(selef.state == 'resolved'){
	   onResolved(selef.value)
    }else if(selef.state == 'resolved'){
       onRejected(selef.msg)
    }
}
**项目概述:** 本资源提供了一套采用Vue.js与JavaScript技术栈构建的古籍文献文字检测与识别系统的完整源代码及相关项目文档。当前系统版本为`v4.0+`,基于`vue-cli`脚手架工具开发。 **环境配置与运行指引:** 1. **获取项目文件**后,进入项目主目录。 2. 执行依赖安装命令: ```bash npm install ``` 若网络环境导致安装缓慢,可通过指定镜像源加速: ```bash npm install --registry=https://registry.npm.taobao.org ``` 3. 启动本地开发服务器: ```bash npm run dev ``` 启动后,可在浏览器中查看运行效果。 **构建与部署:** - 生成测试环境产物: ```bash npm run build:stage ``` - 生成生产环境优化版本: ```bash npm run build:prod ``` **辅助操作命令:** - 预览构建后效果: ```bash npm run preview ``` - 结合资源分析报告预览: ```bash npm run preview -- --report ``` - 代码质量检查与自动修复: ```bash npm run lint npm run lint -- --fix ``` **适用说明:** 本系统代码经过完整功能验证,运行稳定可靠。适用于计算机科学、人工智能、电子信息工程等相关专业的高校师生、研究人员及开发人员,可用于学术研究、课程实践、毕业设计或项目原型开发。使用者可在现有基础上进行功能扩展或定制修改,以满足特定应用场景需求。 资源来源于网络分享,仅用于学习交流使用,请勿用于商业,如有侵权请联系我删除!
### Promise 实现原理与 JavaScript 源码解析 #### 一、Promise 的基本概念 Promise 是一种异步编程解决方案,它遵循 Promises/A+ 规范[^1]。其核心在于封装了一个可能具有延迟的结果的操作,并提供了统一的接口来处理这些操作的成功或失败。 #### 二、Promise 的状态管理 Promise 对象有三种主要的状态: - **Pending**: 初始状态,既未完成也未失败。 - **Fulfilled**: 成功状态,表示操作成功完成。 - **Rejected**: 失败状态,表示操作未能完成并抛出了错误。 一旦状态从 Pending 变更为 Fulfilled 或 Rejected,则该状态不可逆[^4]。 #### 三、Promise 的核心方法实现 以下是 Promise 的几个重要方法及其工作原理: ##### 1. `then` 方法 `then` 方法用于注册当 Promise 被解决时要执行的回调函数。它的返回值也是一个新的 Promise 实例,从而支持链式调用[^2]。 ```javascript // 示例代码展示 then 方法的工作机制 new Promise((resolve) => { resolve('你好'); }).then((res) => { console.log(res); // 输出 '你好' }); ``` ##### 2. `catch` 方法 `catch` 方法专门用来捕获 Promise 链中的异常。其实质是对 `then` 方法的一个简化版本,仅接收拒绝回调作为参数[^3]。 ```javascript // catch 方法的核心逻辑 Promise.prototype.catch = function(onRejected) { return this.then(null, onRejected); }; ``` ##### 3. `finally` 方法 无论 Promise 是否被解决或拒绝,`finally` 方法都会被执行。它是基于 `then` 方法的一种扩展,主要用于清理资源或其他无关业务逻辑的任务。 ```javascript // finally 方法模拟实现 Promise.prototype.finally = function(callback) { return this.then( (value) => Promise.resolve(callback()).then(() => value), (reason) => Promise.resolve(callback()).then(() => { throw reason }) ); }; ``` #### 四、静态方法的功能剖析 除了实例方法外,Promise 还提供了一些常用的静态方法: ##### 1. `Promise.resolve(value)` 如果传入的是一个已经存在的 Promise,则直接返回这个 Promise;如果是其他类型的值,则将其转换为已解决的 Promise。 ```javascript const resolvedValue = Promise.resolve(42).then((val) => val); // 返回值为 42 ``` ##### 2. `Promise.reject(reason)` 创建一个带有指定原因的拒绝态 Promise。 ```javascript const rejectedReason = Promise.reject(new Error('Error occurred')); rejectedReason.catch(err => console.error(err.message)); // 打印 'Error occurred' ``` ##### 3. `Promise.all(iterable)` 接受一个可迭代对象(如数组),只有所有的 Promise 都解决了才会继续往下走,否则立即进入 Reject 状态。 ```javascript Promise.all([Promise.resolve(1), Promise.resolve(2)]).then(results => console.log(results)); // 结果为 [1, 2] ``` #### 五、完整的简易版 Promise 实现 下面给出一个简单的 Promise实现,涵盖了上述提到的主要功能: ```javascript class MyPromise { constructor(executor) { this.state = 'pending'; this.value = undefined; this.reason = undefined; const resolve = (value) => { if (this.state === 'pending') { this.state = 'fulfilled'; this.value = value; } }; const reject = (reason) => { if (this.state === 'pending') { this.state = 'rejected'; this.reason = reason; } }; try { executor(resolve, reject); } catch (error) { reject(error); } } then(onFulfilled, onRejected) { return new MyPromise((resolve, reject) => { if (this.state === 'fulfilled') { setTimeout(() => { try { resolve(onFulfilled(this.value)); } catch (err) { reject(err); } }, 0); } if (this.state === 'rejected') { setTimeout(() => { try { reject(onRejected(this.reason)); } catch (err) { reject(err); } }, 0); } }); } catch(onRejected) { return this.then(null, onRejected); } } ``` 此代码片段展示了如何手动构建一个符合 Promises/A+ 标准的基础 Promise 架构[^5]。 ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值