参考链接:JavaScript Promise:简介 
 
Promise 是一个解决异步操作的对象。$.ajax 」。  
 
一个简单的例子 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 const  imageLoad = url  =>new  Promise ((resolve, reject ) =>  {  const  image = new  Image()   image.onload = function (          resolve('加载成功' )   }   image.onerror = function (     reject(new  Error ('加载失败' ))   }   image.src = url }) imageLoad('https://avatars3.githubusercontent.com/u/9067839?s=460&v=4' )   .then(          success => console .log(success),          error => console .log(error)   ) 
认真看了上面的典型的简单的 Promise 例子,开发者应该对 Promise 不陌生了,至少对 then 方法不陌 😆
Promise 实例的状态 每个 Promise 实例都有一个状态,初始为 PendingResolvedRejected
Promise 原型链方法 
原型链方法又称实例方法
 
Promise.prototype.then() 
then 方法接受2个函数参数,第一个函数参数将状态变为 Resolved,调用第二个函数参数将状态变为 Rejected
then 方法内部 return 详解:Promise 对象Promise对象,那么下一个 then 的形参就是这个 Promise 对象执行方法的实参
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 function  newPromise (    return  new  Promise (resolve  =>'I was resolved' )) } new  Promise (resolve  =>        resolve()     })     .then(()  =>                  return  '我只是一个字符串'      })     .then(_data  =>         console .log(_data)               })     .then(_data  =>         console .log(_data)                   return  newPromise()     })     .then(_data  =>         console .log(_data)      }) 
Promise.prototype.catch() 
catch 与 then 一样,返回值是 新的 Promise 对象 
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 new  Promise (resolve  =>        resolve(msg)      })     .then(_data  =>console .log(_data))      .catch(_error  =>console .log(_error))  new  Promise (resolve  =>        resolve(msg)      })     .catch(_error  =>console .log(_error))      .then(_data  =>console .log(_data))  new  Promise (resolve  =>        resolve('OK' )     })     .then(_data  =>         var  test = unnamed      })     .catch(_error  =>console .log(_error))  new  Promise (resolve  =>        resolve('OK' )     })     .then(_data  =>         console .log(_data)          var  test = unnamed_one      })     .catch(_error  =>         console .log(_error)          var  test = unnamed_two      })     .catch(_error  =>console .log(_error))  
看过上面的代码分析后,至少可以总结出:
还有:catch 方法是then(null, rejection)的别名(如下代码)
1 2 3 4 5 6 7 8 9 Promise .resolve()    .then(_success  =>console .log(_success))     .catch(_error  =>console .log(_error)) Promise .resolve()    .then(_success  =>console .log(_success))     .then(null , _error => console .log(_error)) 
注意:catch 不能捕获异步错误,请看如下代码:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 let  _promise1 = ()  =>new  Promise (()  =>        throw  new  TypeError ('I am a error' )      }),     _promise2 = ()  =>new  Promise (()  =>         setTimeout(()  =>             throw  new  TypeError ('I am a error' )          }, 0 )     }),     _promise3 = ()  =>new  Promise ((resolve, reject ) =>  {         setTimeout(()  =>             reject('I am a error' )          }, 0 )     }) _promise1()     .catch(_error  =>console .log(_error))  _promise2()     .catch(_error  =>console .log(_error))  _promise3()     .catch(_error  =>console .log(_error))  
Promise 的静态方法 Promise.resolve(param) 
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 let  thenable = {    then: function (resolve, reject )          resolve('I was resolved' )     } } var  _promise = Promise .resolve(thenable)_promise.then(_data  =>console .log(_data))  var  _promise = Promise .resolve('I am promise' )_promise.then(_data  =>console .log(_data))  
Promise.reject() 
和Promise.resolve()一样,只是返回的 Promise 实例的状态为rejectedrejected
1 2 3 4 5 var  _promise = Promise .reject('error' )_promise.catch(_errpr  =>console .log('I am error' ))  
Promise.all() 
all方法可以接受一个具有 Iterator 接口的对象(一般为数组),且返回的每个成员都是 Promise 实例all方法依旧返回一个新的 Promise 实例resolved时, all 方法才返回resolved,反之则然
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 let  _promise = _value  =>new  Promise ((resolve, reject ) =>  {    setTimeout(_value  =>                  if  (/^resolve/ .test(_value)) {             resolve(_value)             return          }         reject(_value)     }, 1000 , _value) }) Promise     .all([_promise('resolveOne' ), _promise('resolveTwo' )])     .then(_success  =>console .log(_success))      .catch(_error  =>console .log(_error))  Promise     .all([_promise('resolveOne' ), _promise('rejectOne' )])     .then(_success  =>console .log(_success))      .catch(_error  =>console .log(_error))  
Promise.race() 
race 方法和 all 方法用法一模一样,只是返回值有点差别
1 2 3 4 5 6 7 8 9 10 11 12 let  _promise = (_time, _value ) =>  new  Promise ((resolve, reject ) =>  {    setTimeout(()  => }) Promise     .race([_promise(2000 , 'resolveSlow' ), _promise(1000 , 'resolveFast' )])     .then(_success  =>console .log(_success))  
Promise 总结 Promise 可以看做是回调函数的改进方案,解决了 callback 的回调深渊