1
0
mirror of https://github.com/ruanyf/es6tutorial.git synced 2025-05-25 03:02:21 +00:00

edit Promise

This commit is contained in:
ruanyf 2015-09-13 08:48:49 +08:00
parent 3150ae90fe
commit f5365acb2a

View File

@ -2,21 +2,21 @@
## Promise的含义 ## Promise的含义
Promise在JavaScript语言早有实现ES6将其写进了语言标准统一了用法原生提供了Promise对象。 `Promise`在JavaScript语言早有实现ES6将其写进了语言标准统一了用法原生提供了`Promise`对象。
所谓Promise就是一个对象用来传递异步操作的消息。它代表了某个未来才会知道结果的事件通常是一个异步操作并且这个事件提供统一的API可供进一步处理。 所谓`Promise`就是一个对象用来传递异步操作的消息。它代表了某个未来才会知道结果的事件通常是一个异步操作并且这个事件提供统一的API可供进一步处理。
Promise对象有以下两个特点。 `Promise`对象有以下两个特点。
1对象的状态不受外界影响。Promise对象代表一个异步操作有三种状态Pending进行中、Resolved已完成又称Fulfilled和Rejected已失败。只有异步操作的结果可以决定当前是哪一种状态任何其他操作都无法改变这个状态。这也是Promise这个名字的由来它的英语意思就是“承诺”表示其他手段无法改变。 1对象的状态不受外界影响。`Promise`对象代表一个异步操作,有三种状态:`Pending`(进行中)、`Resolved`已完成又称Fulfilled`Rejected`(已失败)。只有异步操作的结果,可以决定当前是哪一种状态,任何其他操作都无法改变这个状态。这也是`Promise`这个名字的由来,它的英语意思就是“承诺”,表示其他手段无法改变。
2一旦状态改变就不会再变任何时候都可以得到这个结果。Promise对象的状态改变只有两种可能从Pending变为Resolved和从Pending变为Rejected。只要这两种情况发生状态就凝固了不会再变了会一直保持这个结果。就算改变已经发生了你再对Promise对象添加回调函数也会立即得到这个结果。这与事件Event完全不同事件的特点是如果你错过了它再去监听是得不到结果的。 2一旦状态改变就不会再变任何时候都可以得到这个结果。`Promise`对象的状态改变,只有两种可能:从`Pending`变为`Resolved`和从`Pending`变为`Rejected`。只要这两种情况发生,状态就凝固了,不会再变了,会一直保持这个结果。就算改变已经发生了,你再对`Promise`对象添加回调函数也会立即得到这个结果。这与事件Event完全不同事件的特点是如果你错过了它再去监听是得不到结果的。
有了Promise对象就可以将异步操作以同步操作的流程表达出来避免了层层嵌套的回调函数。此外Promise对象提供统一的接口使得控制异步操作更加容易。 有了`Promise`对象,就可以将异步操作以同步操作的流程表达出来,避免了层层嵌套的回调函数。此外,`Promise`对象提供统一的接口,使得控制异步操作更加容易。
Promise也有一些缺点。首先无法取消Promise一旦新建它就会立即执行无法中途取消。其次如果不设置回调函数Promise内部抛出的错误不会反应到外部。第三当处于Pending状态时无法得知目前进展到哪一个阶段刚刚开始还是即将完成 `Promise`也有一些缺点。首先,无法取消`Promise`,一旦新建它就会立即执行,无法中途取消。其次,如果不设置回调函数,`Promise`内部抛出的错误,不会反应到外部。第三,当处于`Pending`状态时,无法得知目前进展到哪一个阶段(刚刚开始还是即将完成)。
如果某些事件不断地反复发生一般来说使用stream模式是比部署Promise更好的选择。 如果某些事件不断地反复发生一般来说使用stream模式是比部署`Promise`更好的选择。
## 基本用法 ## 基本用法
@ -443,9 +443,26 @@ p.then(null, function (s){
上面代码生成一个Promise对象的实例p状态为rejected回调函数会立即执行。 上面代码生成一个Promise对象的实例p状态为rejected回调函数会立即执行。
## Generator函数与Promise的结合 ## 应用
使用Generator函数管理流程遇到异步操作的时候通常返回一个Promise对象。 ### 加载图片
我们可以将图片的加载写成一个`Promise`,一旦加载完成,`Promise`的状态就发生变化。
```javascript
conset preloadImage = function (path) {
return new Promise(function (resolve, reject) {
var image = new Image();
image.onload = resolve;
image.onerror = reject;
image.src = path;
});
};
```
### Generator函数与Promise的结合
使用Generator函数管理流程遇到异步操作的时候通常返回一个`Promise`对象。
```javascript ```javascript
function getFoo () { function getFoo () {
@ -482,7 +499,7 @@ function run (generator) {
run(g); run(g);
``` ```
上面代码的Generator函数g之中有一个异步操作getFoo它返回的就是一个Promise对象。函数run用来处理这个Promise对象并调用下一个next方法。 上面代码的Generator函数`g`之中,有一个异步操作`getFoo`,它返回的就是一个`Promise`对象。函数`run`用来处理这个`Promise`对象,并调用下一个`next`方法。
## async函数 ## async函数