科百科
当前位置: 首页 范文大全

promise 获取数据(自己造轮子超详细)

时间:2023-08-07 作者: 小编 阅读量: 3 栏目名: 范文大全

“我最近学习了Promise对象的使用,真是太棒了,使用链式调用代替了嵌套回调,代码书写起来很方便还便于阅读”小白说。“OK,成交了”小白晃了晃手里的星巴克优惠券。在这之前要确保你完全明白如何使用他的各个方法。this.status用来存放执行状态。最后我们来看下完整的Promise代码实现。“完美运行,非常棒,难怪您会先让我学习发布/订阅模式,非常感谢”小白向老麦克竖起了大拇指。

“我最近学习了Promise对象的使用,真是太棒了,使用链式调用代替了嵌套回调,代码书写起来很方便还便于阅读” 小白说。

麦克黑:“是的,Promise是一种异步编程解决方案,尤其在多接口调用的时候会起到非常大的作用,方便开发” 。

小白挠挠头说:“我阅读了代码知道了他的使用方式,我知道他有三种状态:pending(进行中)、fulfilled(已成功)和rejected(已失败),也能够在项目中熟练使用,但我并不知道Promise内部的实现原理” 。

麦克黑:“如果你感兴趣,我觉的你可以尝试自己造轮子,来自己写一个Promise对象,”

小白:“如果可以的话就太棒了,但是我应该如何着手写一个自己的Promise对象呢?”

“当然可以,不过,以下谈话价值两杯咖啡外加一个鸡肉卷”麦克黑狡黠的一笑。

“OK,成交了” 小白晃了晃手里的星巴克优惠券。

今天我们来写一个Promise对象

一。在这之前要确保你完全明白如何使用他的各个方法。如果还不清楚那么就去看下es6的文档,不然下面的内容可能会看不明白

二。你完全了解发布/订阅模式,这会然让你对后面的代码更容易理解,如果还不清楚就去看下我们上次的谈话 《教你如何用ES6发布/订阅模式约女朋友》”

“那么首先你来写一个最常用的Promise的使用方法”老麦克说到

“没问题”

“写的不错,那么我们就编写一段代码让这段代码能够正常的运行”。

首先我们编写一个Promise方法

在Promise方法里我定义了 两个数组 分别用来存放 成功时和失败时要执行的函数,你还记得发布订阅者模式吗?

this.status 用来存放执行状态。 this.value存放 返回的内容(不管成功与否)

接下来我们执行了 startResolve(this, fn); 方法。但现在我还不准备讲解他的实现方式。

我们先实现then方法

当我们调用then方法的时候首先会判断this.status的状态

  • this.status =0 则 执行 addQueue
  • this.status =1 则 执行 reject
  • this.status =2 则 执行 reject

那么我们首先看下addQueue方法。

addQueue方法的实现

你看到了吗,开始push了,就像发布订阅模式一样。

resolve方法的实现

看下成功数组(resolves)里有没有函数,如果没有直接返回false ,如果有函数我们就把失败数组(rejects)的函数清除掉。修改status的状态为 1,也就是resolve 解析成功然后调用resolves 列表里的函数,也就是我们从then里的函数push进来的函数。

reject方法的实现

和resolve是一个道理,你懂的,不解释。

最后我们来看下startResolve都干了些什么。

startResolve() 方法的实现

看到了吧,延迟执行,在这里我们用setTimeout来实现延迟在实际的es6的promise对象中他使用的是 asap模块来实现的

var asap = require('asap/raw');

总结:

也就是说我们先执行了then方法,把then里的两个匿名函数push到了promise的成功函数数组(resolves)和失败函数数组里(rejects),然后在执行pormise里的函数等成功或者失败以后再调用then里提供的方法。懂了吗?

最后我们来看下完整的Promise代码实现。

到此我们的代码编写完毕,最开始的代码还记得吗?

在浏览器中运行一下来验证我们的代码是否成功!

“完美运行,非常棒,难怪您会先让我学习发布/订阅模式,非常感谢”小白向老麦克竖起了大拇指。

    推荐阅读
  • 素炒平菇的做法(好吃的清炒平菇)

    ,我来为大家讲解一下关于素炒平菇的做法?跟着小编一起来看一看吧!素炒平菇的做法蘑菇洗净切片辣椒切段,葱蒜改刀锅内热油,爆香葱蒜倒入圆菇,放盐,炒制稍稍软,有水出来加入西红柿酱上色,加入青椒大火翻炒。

  • 你要知道的财务制度(几个好的财务制度)

    企业内部财务制度的依据是国家统一的财务制度。同时应当充分考虑企业内部的生产经营特点以及管理要求。尽量避免无计划、无定额使用资金。

  • 去完黑头收缩毛孔的最好方法(怎样去完黑头收缩毛孔)

    但绿豆粉过大的颗料需要有润滑相助,蛋清即承担了这个工作。使用黑头导出液这是专家认为最科学的方法,当然也是最彻底的。其程序是先用热蒸或热敷让鼻子的毛孔充分打开,然后将适量的黑头导出液滴在化妆棉上,在鼻子上贴15分钟后,撕掉化妆棉,就可以看见上面粘了很多黑头和白头。并且,挤后要马上涂抹收缩水以助毛孔恢复正常。

  • 寻常的反义词(你知道吗)

    下面希望有你要的答案,我们一起来看看吧!寻常的反义词寻常的反义词:别致、特殊、异常、超常、奇特、神奇、奇妙、异样。寻常,汉语词汇拼音:xúncháng释义:1.寻、常,皆古代长度单位2.比喻长或多3.平常;普通4.经常;平时。寻常的近义词是普通,反义词是不同。

  • 郭富城第一次夺金像奖(娱乐圈五位赛车手)

    据悉,当时车里坐着的是林志颖和他的儿子,两人已经被送往医院,林志颖受伤较为严重,造成颜面骨折,但是没有生命危险。而经过警方的鉴定,林志颖并未涉嫌酒驾。这场车祸让林志颖的人生陷入了谷底。郭富城名下有多辆豪车,已经曝光的包括全球限量40辆价值2200万的法拉利,两辆保时捷,一辆兰博基尼,甚至连买菜车都是奥迪。

  • 五一旅游景点推荐情侣(五一情侣国内推荐旅游景点)

    在登顶台阶的扶手边,最吸引人的莫过于栏杆上那密密麻麻的镌刻了无数情侣名字的同心锁,这构成了峨眉山另一到独特的风景线。有趣的是,许多同心锁原本没有钥匙眼,这表示一旦订情,就无退路。被游客喻为“情人旅游线”。是湖南省著名的风景名胜区,有“中国最美丽的小城”之誉。这个岛好像是专门为情侣准备的。

  • 女性朋友生日祝福语(送给女朋友生日祝福语)

    女性朋友生日祝福语?女性朋友生日祝福语打起鼓来敲起锣,长了一岁你乐呵呵;又吃蛋糕又聚会,吃着火锅唱着歌;祝你生日最快乐,明媚阳光洒心窝;平平安安开心过,幸福如意收获多。好运不断,幸福一生。不管人生多么艰难,也要眉眼带笑,生日快乐sweety。总有一份思念萦绕心头,总有一个回忆心间绽放,总有一个梦想展翅飞翔,总有一股愿望正在期待,总有一个日子真的等待。今天,烛光为你而燃放美丽,祝亲爱的生日快乐!

  • 编程学习博主(Tony老师酷爱编程好手艺却用在)

    警方立刻着手调查,发现这个木马病毒是由外省一名章姓男子利用虚假身份放置的。截至案发,这个木马病毒已经盗取了700多组游戏账号密码。警方奔赴外省,将章某抓获归案。警方立刻兵分多路,对杨某和接码平台的幕后人员进行调查。在山东,民警将杨某抓获。在校学生搭建接码平台,非法获利近百万元抓捕杨某的同时,另一组民警也将接码平台幕后操作者抓获,他们是4名在校大学生。

  • 外卖高峰期跑单技巧(冬天跑外卖注意事项及跑单技巧)

    ①出门前首先检查车闸刹车是否正常,尽量放低车座,降低重心,然后再检查车灯,喇叭功能是否正常!另外和前方车辆保持一定的距离,远离大型货车,泥土车,搅拌车,油罐车,防止他们视线盲区。⑤遇见情况尽早下车,切勿与机动车抢道防止被发生侧滑的机动车碰伤;遇到积雪地面和凹凸不平的冰面时,最好下车推行通过。