博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
理解 $q 和 promise基本用法-2 4.17
阅读量:6497 次
发布时间:2019-06-24

本文共 1433 字,大约阅读时间需要 4 分钟。

可以先看我的第一篇文章

$q 和 promise

需要在 angular 中掌握异步的知识,我们需要掌握这几个重要的知识点,q,http, promise

  • 下面着重讲解一下 $q 的功能和它的 api 的使用。

如何理解$q deferred object?

  • $q.defer: 预订和延期

假设有一个家具厂,而它有一个VIP客户张先生。 有一天张先生需要一个豪华衣柜,于是,他打电话给家具厂说我需要一个衣柜,回头做好了给我送来,这个操作就叫**$q.defer**,也就是延期,因为这个衣柜不是现在要的,所以张先生这是在发起一个可延期的请求。

  • promise:回执单(承诺)
  • 记录 promise:deferred,(延期事件)

同时,家具厂给他留下了一个回执号,并对他说:我们做好了会给您送过去,放心吧。这叫做==promise==,也就是承诺。 这样,这个==defer==算是正式创建了,于是他把这件事记录在自己的日记上,并且同时记录了回执号,这叫做==deferred==,也就是已延期事件。

  • 异步:等待货物送来,该干嘛干嘛
  • deferred.resolve :已收到货物(已解决)

现在,张先生就不用再去想着这件事了,该做什么做什么,这就是“异步”的含义。 假设家具厂在一周后做完了这个衣柜,并如约送到了张先生家(包邮哦,亲),这就叫做==deferred.resolve(衣柜)==,也就是“已解决”。而这时候张先生只要签收一下这个(衣柜)参数就行了,当然,这个“邮包”中也不一定只有衣柜,还可以包含别的东西,比如厂家宣传资料、产品名录等。整个过程中轻松愉快,谁也没等谁,没有浪费任何时间。

  • deferred.reject:拒绝,没有限制

假设家具厂在评估后发现这个规格的衣柜我们做不了,那么它就需要==deferred.reject(理由)==,也就是“拒绝”。拒绝没有时间限制,可以发生在给出承诺之后的任何时候,甚至可能发生在快做完的时候。而且拒绝时候的参数也不仅仅限于理由,还可以包含一个道歉信,违约金之类的,总之,你想给他什么就给他什么,如果你觉得不会惹恼客户,那么不给也没关系。

  • $q.when(function(resolve,reject){}):现有的东西,直接可执行的东西
  • deferred.noyify():发送通知,异步进展情况

假设家具厂发现,自己正好有一个符合张先生要求的存货,它就可以用==$q.when(现有衣柜)==来把这个承诺给张先生,这件事就立即被解决了,皆大欢喜,张先生可不在乎你是从头做的还是现有的成品,只会惊叹于你们的效率之高。 假设这个家具厂对客户格外的细心,它还可能通过deferred.notify(进展情况)给张先生发送进展情况的“通知”。 这样,整个异步流程就圆满完成,无论成功或者失败,张先生都没有往里面投入任何额外的时间成本。

  • $q.all:多个 promise

好,我们再扩展一下这个故事: 张先生这次需要做一个桌子,三把椅子,一张席梦思,但是他不希望今天收到个桌子,明天收到个椅子,后天又得签收一次席梦思,而是希望家具厂做好了之后一次性送过来,但是他下单的时候又是分别下单的,那么他就可以重新跟家具厂要一个包含上述三个承诺的新承诺,这就是$q.all(桌子承诺,椅子承诺,席梦思承诺), 这样,他就不用再关注以前的三个承诺了,直接等待这个新的承诺完成,到时候只要一次性签收了前面的这些承诺就行了。

转载地址:http://lpuyo.baihongyu.com/

你可能感兴趣的文章
bzoj1034
查看>>
百度地图 鼠标绘制,获取矩形,多边形的顶点经纬度
查看>>
回文树模板
查看>>
struts2之防止表单重复提交
查看>>
【转】Netty系列之Netty并发编程分析
查看>>
cf591d
查看>>
图片存储系统TFS
查看>>
MYSQL备份与恢复
查看>>
贪心/数学 Codeforces Round #212 (Div. 2) A. Two Semiknights Meet
查看>>
Python类__call__()方法
查看>>
「小程序JAVA实战」 小程序wxss样式文件的使用(七)
查看>>
容斥定理,皮克公式
查看>>
[LeetCode] Rotate List
查看>>
javascript Date format(js日期格式化)(转)
查看>>
git+idea
查看>>
集合异常测试
查看>>
cocos2d游戏开发,常用工具集合
查看>>
FatTree胖树拓扑结构
查看>>
Kafka深度解析
查看>>
unsigned 后面不跟类型的情况
查看>>