学习 JavaScript Promises 的最佳资源

译者:少年阿布DX
链接:http://www.zcfy.cc/article/1040
原文:http://codeutopia.net/blog/2016/06/29/the-best-resources-to-learn-about-javascript-promises/

Promises 既可能是福音,也可能是灾难。他本被期望解决“回调金字塔的噩梦”,但反而他们总以困惑而告终。(以及我想把它叫做“回调魔域”。这对本文并无影响,我只是喜欢印第安纳琼斯)。(译者注:魔域奇兵(Temple of Doom)是夺宝奇兵的第二部,作者此处在玩梗...)

尽管 promises 确有帮助,但它比普通的回调复杂多了。使用回调,你只需要传递一个函数,也许在其中又插入了另一个函数。但使用 Promise 的话,函数更多了。

Promise 链可能会很让人困惑,因为异常、普通的 JS 值和 Promise 都会不同地影响它。设置更复杂的流程也可能会很困难,因为你需要变戏法似的处理多个 Promise 以及它们的返回值。

而且,错误处理也是个主题。Promise 的默认行为十分方便:未处理的异常会被忽略,因为很显然,写这份代码的人讨厌所有人并且想你享受额外的愉悦的 debug 时间。

但 Promise 是未来。新的异步 API 都倾向于变为基于 Promise 的。新的 JavaScript 特性如 async/await 也是基于 Promise 的。

这就意味着,你越熟悉 Promise,你对未来准备越充分 —— 更别提使用得当的话,尽管复杂,Promise 是非常方便的。

正因为这点的重要性,以及我时常收到的关于 Promise 的问题,我为你们把关于 Promise 最佳的资料集合成了一个列表!

在下面你会发现大量 Promise 的资料,从基础到超深度!

1. 起步

David Walsh 写的这篇 Promise 文章 是极佳的入门读物。它很好地概括了 Promise 是什么以及它们是如何工作的,并提供了实例。

2. 深度理解 Promise

想更深度地理解 Promise 是如何工作的话,Pony Foo 上的这篇文章很棒。它也提供了大量关于如何使用与 Promise 相关的函数的例子。

如果你对链式的 Promise 如何工作抱有疑问的话,可视化它会很有帮助。这儿有一个工具能用来获取 Promise 链工作机制的图像表示。

3. 关于 Promise 的免费章节

想要一份 Promise 的完全解读,包含许多实例甚至还有需要避免的常见错误,可读探索 ES6 之用于异步编程的 Promise

另一个有大量实例的完全解读资源是这本 YDKJS(你不知道的 JavaScript)的异步与性能章节。

4. 参考材料 / 快捷信息

如果想要快速参考,MDN 无与伦比。如果你需要快速地查阅某些东西的工作原理,或者一个函数的资料,比如查阅它的参数信息,MDN Promise 参考资料 会是我的不二选择。

5. 常见错误与反模式

开发者们在使用 Promises 经常会犯一些常见的错误。想要一览这些错误,并获得替代方案的实例的话,读 Tao of Code 上的这篇 Promise 反模式吧。

6. Promise 如何工作

你想知道知道 Promise 实际上是怎么样工作的吗?Promise 是怎么做到 Promise 的?那就读这篇 Promise 细枝末节吧,该文一步步地用纯 JavaScript 实现了 Promise。

7. Promise 高级用法

尽管标准的 Promise 很有用,但更为复杂的应用的需要不止于此。Bluebird 提供了大量 Promise 相关的功能,能大大简化复杂的使用。

YDKJS 的作者 Kyle Simpson 的 Asynquence 也是可选方案。它支持了很多有趣的特性,多少有点像 Bluebird。

8. Promise 单元测试

最后,但同样非常重要的,当你想用 promise 来测试代码时,就来读我的 JavaScript Promise 与单元测试权威指南)吧。

最后

本文应该覆盖了相当多想象范围内的 Promise 相关的场景。你还有其他觉得有帮助的资源吗?写在评论里吧!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,125评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,293评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,054评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,077评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,096评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,062评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,988评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,817评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,266评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,486评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,646评论 1 347
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,375评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,974评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,621评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,796评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,642评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,538评论 2 352

推荐阅读更多精彩内容

  • 英文:Nolan Lawson 译文:伯乐在线专栏作者 - abell123如有好文章投稿,请点击 → 这里了解...
    北方蜘蛛阅读 6,257评论 1 10
  • 异步编程对JavaScript语言太重要。Javascript语言的执行环境是“单线程”的,如果没有异步编程,根本...
    呼呼哥阅读 7,308评论 5 22
  • 特别说明,为便于查阅,文章转自https://github.com/getify/You-Dont-Know-JS...
    杀破狼real阅读 650评论 0 3
  • 本文作者就是我,简书的microkof。如果您觉得本文对您的工作有意义,产生了不可估量的价值,那么请您不吝打赏我,...
    microkof阅读 15,949评论 9 40
  • 知道结果子的差不多都会开花。就是无花果,虽然叫无花果其实它的花开在果子里。枸杞子吃的很多,见到的都是红彤彤的果子,...
    王了一一阅读 706评论 18 17