在JS中promise的实现过程是怎样,原理怎么理解
Admin 2022-06-20 群英技术资讯 1015 次浏览
很多朋友都对“在JS中promise的实现过程是怎样,原理怎么理解”的内容比较感兴趣,对此小编整理了相关的知识分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获,那么感兴趣的朋友就继续往下看吧!1. 首先我们需要在这里放置一个promise函数本体 后面要在里面添加resolve、reject的执行函数
function Promise(execotor) {}
2. 原装promise中有then与catch这两个主要的方法,所以我们要给promise的原型挂载then与catch
Promise.prototype.then = function (onResolved, onRejected) {}
Promise.prototype.catch = function (onRejected) {}
3. 给promise挂载几个常见方法 resolve、reject、all、race等等
resolve:返回的是一个指定结果的promise对象
Promise.resolve = function (value) { }
reject:返回失败状态的方法
Promise.reject = function (value) { }
all:返回一个promise对象,只有当promise都返回的时候,这个状态才算成功
Promise.all = function (value) { }
race:返回一个promise对象,它的状态是由第一个返回的对象确定的,这个race里面哪个函数先执行完,就直接返回第一个值,其他的继续执行
Promise.race = function (value) { }
4. 全局声明mypromise
window.Promise = Promise
5. 建立一个自执行函数 将上述内容全部包裹进去
(function (window) {
})()
1.填充function Promise()
(1)let self = this固定一个function内部的this,这个this在后面会发挥很大作用
(2)self.status = 'pending'为Promise函数本体添加一个基础状态‘pending'
(3)self.data = undefined建立一个data源,用来存储resolve传回来的结果
(4)self.callbacks = []建立一个数组,用来将promise中的回调全部保存起来
2.填充function resolve()
(1) if (self.status !== 'pending') { return }判断当前传入进程的状态是否为pending,是就继续下面的操作,不是就直接返回
promise内部有三种状态pending、resolved、rejected,这三种状态都是一种开关变量,如果该状态从pending转为其他状态后将无法改变。
(2)self.status = 'resolved'将该进程的状态改为resolved
(3)self.data = value将value存起来,待会then中的回调会需要使用该数据
(4)放上最重要的执行函数部分,如果sele.data中有待执行的callback函数,立即异步执行它
if (self.callbacks.length > 0) {
setTimeout(() => {
self.callbacks.forEach(callbackObj => {
callbackObj.onResolved(value)
})
}, 0)
}
3.填充function reject()
(1) 与resolve函数相同,此处简略
4.填充execotor方法
promise主体在执行时如果出错,错误信息被catch捕捉,此时catch会跳至该函数来单独执行一个reject
try {
execotor(resolve, reject)
} catch (error) {
reject(error)
}
5.填充.then函数
首先我们要区分传入进程的状态,如果是pending状态就把回调函数存起来,如果不是pending状态就干点什么它应该做的
(1)if (self.status === 'pending')如果当前的状态是pending的话,我们就把它保存起来
self.callbacks.push({
onResolved() { onResolved(self.data) },
onRejected() { onRejected(self.data) }
})
(2)else if (self.status === 'resolved')如果status的状态是resolved
我们就开开心心的给它执行一下
setTimeout(() => {
onResolved(self.data)
}, 0)
可是有这么一种状态:resolve没有执行,但此时状态却已经改变了,我们就不能执行resolve而改为执行rejected
else{
setTimeout(() => {
onRejecyed(self.data)
}, 0)
}
经过了如同怎么把大象塞进冰箱一样“简略”的两步,我们就实现了一个简易的Promise
是不是很简单呀,快叫上身边的小伙伴一起来试一试吧!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
这篇文章主要介绍了一个处理react异常的ErrorBoundary组件,简单实用,代码详细,对这个组件感兴趣的朋友可以参考下
本篇文章给大家带来了关于javascript的相关知识,其中主要介绍了JavaScript的书写规则、变量的声明格式、变量的命名规则、及注意事项,变量的数据类型,数据类型的分类,空(null) 与 未定义(undefined)的用法,下面一起来看一下,希望对大家有帮助。
今天主要给大家分享用JS怎样学习算法复杂度的内容,一些朋友可能对于算法复杂度不是很了解,对此本文就给大家来介绍一下算法复杂度,下文代码有一定的参考价值,需要的朋友可以看一看。
今天给大家分享的是用JavaScript实现滑块验证功能,在实际的项目中,常常会遇到验证功能的需求,因此分享给大家做个参考。下文JavaScript实现登录的滑块验证代码,感兴趣的朋友可以参考,接下来我们一起来详细看看吧。
有一些刚接触JavaScript的新手对于JavaScript语句写在哪里会有点困惑,对此这篇我们就简单的了解一下JavaScript语句的写法。我们要知道JavaScript语句是必须嵌套在“script”标签中,接下来我们来看看要注意哪些及怎样写。
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008