前言
写作初衷
本书的目的是以目前还在制定中的ECMAScript 6 Promises规范为中心,着重向各位读者介绍JavaScript中对Promise相关技术的支持情况。
通过阅读本书,我们希望各位读者能在下面三个目标上有所收获。
- 学习Promise相关内容,能熟练使用Promise模式并进行测试
- 学习Promise适合什么、不适合什么,知道Promise不是万能的,不能什么都想用Promise来解决
- 以ES6 Promises为基础进行学习,逐渐发展形成自己的风格
像上面所提到的那样,本书主要是以ES6 Promises,即JavaScript的标准规范为基础的、Promise的相关知识为主要讲解内容。
在Firefox和Chrome这样技术比较超前的浏览器上,不需要安装额外的插件就能使用Promise功能,此外ES6 Promises的规范来源于Promises/A+社区,它有很多版本的实现。
我们将会从基础API开始介绍可以在浏览器的原生支持或者通过插件支持的Promise功能。 也希望各位读者能了解这其中Promise适合干什么,不适合干什么,能根据实际需求选择合适的技术实现方案。
开始阅读之前
本书的阅读对象需要对JavaScript有基本的了解和知识。
- JavaScript: The Good Parts
- JavaScript Patterns
- JavaScript: The Definitive Guide, 6th Edition
- Perfect JavaScript(日文版)
- Effective JavaScript(日文版)
如果你读过上面的其中一本的话,就应该非常容易理解本书的内容了。
另外如果你有使用JavaScript编写Web应用程序的经验,或者使用Node.js编写过命令行、服务器端程序的话,那么你可能会对本文中的一些内容感到非常熟悉。
本书的一本分章节将会以Node.js环境为背景进行说明,如果你有Node.js基础的话,那么一定会非常容易理解这部分内容了。
格式约定
本书为了节约篇幅,用了下面一些格式上的约定。
- 关于Promise的术语请参考术语集。
- 一般一个名词第一次出现时都会附带相关链接。
- 实例方法都用 instance#method 的形式。
- 比如 Promise#then 这种写法表示的是 Promise的实例对象的 then 这一方法。
- 对象方法都采用 object.method 的形式。
- 这沿用了JavaScript中的使用方式,Promise.all 表示的是一个静态方法。
这部分内容主要讲述的是对正文部分的补充说明。
推荐浏览器
我们推荐使用内置对Promise支持的浏览器来阅读本书。
Firefox和Chrome的话都支持ES6 Promises标准。
此外,虽然不是推荐的阅读环境,但是读者还是能在iOS等移动终端上阅读本书。
运行示例代码
本网站使用了Promise的Polyfill类库,因此即使在不支持Promise的浏览器上也能执行示例代码。
此外像下面这样,各位读者可以通过运行按钮来运行可执行的示例代码。
var promise = new Promise(function(resolve){
resolve(42);
});
promise.then(function(value){
console.log(value);
}).catch(function(error){
console.error(error);
});
[运行]
按下 [运行] 按钮之后,代码区会变成编辑区,代码也会被执行。当然你也可以通过这个按钮再次运行代码。
[清除log] 按钮用于清除由 console.log 打印出来的log。
[退出]按钮用来退出编辑模式。
如果你对哪里有疑问的话,都可以现场修改代码并执行,以加深对该部分代码的理解。
本书源代码/License
本书中示例代码都可以在GitHub上找到。
本书采用 AsciiDoc 格式编写。
此外代码仓库中还包含本书示例代码的测试代码。
源代码的许可证为MIT许可证,文章内容可以基于CC-BY-NC使用。
意见和疑问
如果有意见或者问题的话,可以直接在GitHub上提Issue即可。
此外,你也可以在 在线聊天 上留言。
各位读者除了能免费阅读本书,也有编辑本书的权利。你可以在GitHub上通过 Pull Requests 来贡献自己的工作。