ES6 Promise

Posted leophen

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了ES6 Promise相关的知识,希望对你有一定的参考价值。

一、什么是 Promise

Promise 对象用于表示一个异步操作的最终状态(完成或失败)以及返回的值。

 

二、Promise 的状态

  • pending(进行中

  • fulfilled(已成功

  • rejected(已失败

Promise 的状态只有两种可能,从 pending 变为 fulfilled 和 从 pending 变为 rejected,一旦状态变化,就不会再改变

 

三、手写一个 Promise

var promise = new Promise((resolve, reject) => 
    if (操作成功) 
        resolve(value)
    
    else 
        reject(error)
    
);

promise.then(function (value) 
    // success(接收resolve传来的数据,做些什么)
, function (error) 
    // failure(接收reject传来的数据,做些什么)
);

其中,promise.then() 接收两个参数,resolved 状态的回调函数和 rejected 状态的回调函数

 

四、Promise.catch()

catch 方法是.then(null, rejection) 的别名,用于指定发生错误时的回调函数

promise.catch(function (error) 
    // failure(接收reject传来的数据或捕捉到then()中的运行报错时,做些什么)
);

 

五、Promise.finally()

finally 方法用于指定不管 Promise 对象最后状态如何,都会执行的操作

promise.finally(function () 
    // 不管什么状态都执行此函数
);

 

六、Promise.all()

all 方法提供了并行执行异步操作的能力,并且在所有异步操作执行完后才执行回调。

all 接收一个数组参数:

(1)只有 getData1、getData2、getData3、getData4 的状态都变成 fulfilled,Promise 的状态才会变成 fulfilled,此时 getData1、getData2、getData3、getData4 的返回值组成一个数组,传递给 Promise 的回调函数

function getData1() 
    return new Promise((resolve, reject) => 
        setTimeout(() => 
            console.log(‘第一条数据加载成功‘);
            resolve(‘data1‘);
        , 1000);
    );


function getData2() 
    return new Promise((resolve, reject) => 
        setTimeout(() => 
            console.log(‘第二条数据加载成功‘);
            resolve(‘data2‘);
        , 1000);
    );


function getData3() 
    return new Promise((resolve, reject) => 
        setTimeout(() => 
            console.log(‘第三条数据加载成功‘);
            resolve(‘data3‘);
        , 1000);
    );


function getData4() 
    return new Promise((resolve, reject) => 
        setTimeout(() => 
            console.log(‘第四条数据加载成功‘);
            resolve(‘data4‘);
        , 2000);
    );


let p = Promise.all([ getData1(), getData2(), getData3(), getData4()]);

p.then(arr => 
    console.log(arr);
);

技术图片

(2)只要 getData1、getData2、getData3、getData4 之中有一个被 rejected,Promise 的状态就变成 rejected,此时第一个被 reject 的实例的返回值,会传递给 Promise 的回调函数

function getData1() 
    return new Promise((resolve, reject) => 
        setTimeout(() => 
            console.log(‘第一条数据加载成功‘);
            resolve(‘data1‘);
        , 1000);
    );


function getData2() 
    return new Promise((resolve, reject) => 
        setTimeout(() => 
            console.log(‘第二条数据加载成功‘);
            resolve(‘data2‘);
        , 1000);
    );


function getData3() 
    return new Promise((resolve, reject) => 
        setTimeout(() => 
            console.log(‘第三条数据加载成功‘);
            resolve(‘data3‘);
        , 1000);
    );


function getData4() 
    return new Promise((resolve, reject) => 
        setTimeout(() => 
            // console.log(‘第四条数据加载成功‘);
            reject(‘data4 err‘);
        , 500);
    );


let p = Promise.all([ getData1(), getData2(), getData3(), getData4()]);

p.then(arr => 
    console.log(arr);
, e => 
    console.log(e);
);

技术图片

 

七、Promise.race()

race 方法同样是将多个 Promise 实例,包装成一个新的 Promise 实例

与 all 方法的区别是:Promise.race([p1, p2, p3]) 里面哪个结果获得的快,就返回哪个结果,不管结果本身是成功状态还是失败状态

function getData1() 
    return new Promise((resolve, reject) => 
        setTimeout(() => 
            console.log(‘第一条数据加载成功‘);
            reject(‘err‘);
        , 500);
    );


function getData2() 
    return new Promise((resolve, reject) => 
        setTimeout(() => 
            console.log(‘第二条数据加载成功‘);
            resolve(‘data2‘);
        , 1000);
    );


function getData3() 
    return new Promise((resolve, reject) => 
        setTimeout(() => 
            console.log(‘第三条数据加载成功‘);
            resolve(‘data3‘);
        , 1000);
    );


let p = Promise.race([ getData1(), getData2(), getData3() ]);

p.then(data => 
    console.log(data);
, e => 
    console.log(e);
)

技术图片

 

以上是关于ES6 Promise的主要内容,如果未能解决你的问题,请参考以下文章

ES6中的Promise

ES6的Promise详解

ES6 中Promise 使用

Web | ES6的异步编程

ES6异步操作Promise

ES6 - Promise 对象