ES6-promise对象

理解

* Promise对象: 代表了未来某个将要发生的事件(通常是一个异步操作)
* 有了promise对象, 可以将异步操作以同步的流程表达出来, 避免了层层嵌套的回调函数(俗称'回调地狱')
* ES6的Promise是一个构造函数, 用来生成promise实例

promise 状态
pending   进行中  ->  初始化 new promise对象时
fulfilled 成功    ->  调用resolve
rejected  失败    ->  调用reject

决议: 状态一旦改变就不可修改
pending->fulfilled 成功
pending->rejected 失败

使用promise基本步骤(2步):


promise 执行流程 - 异步与同步

1 new promise传递的回调函数, 里面的代码是同步执行 (定时器,ajax只执行声明,懂?)
2 then里的回调函数 是异步执行 , 看定时器内部的执行顺序


let  promise = new Promise((resolve,reject)=>{
    console.log(1)
    setTimeout(()=>{
        console.log(4);
            
        resolve('6 哈哈 ');//修改promise的状态为成功

        console.log(5);
        // reject('呵呵 ');//修改promise的状态为失败
    },2000);
});
console.log(2);
    
promise.then((data)=>{
    console.log(data+'成功');
},(data)=>{
    console.log(data+'失败');
})
console.log(3);
p.then(()=>{
    //这里都是异步执行的代码
})

.then()
.catch()
.
Promise.all()
//将多个promise对象合并成一个新的promise对象, 调用resolve传递的数据会整合成一个数组
//只有p1、p2、p3的状态都为成功,p的状态才会为成功
//只要p1、p2、p3之中有一个被失败,p的状态就变成失败
//参数若为空数组的话,会决议为成功
let p = Promise.all([p1,p2....]);
p.then((data)=>{
  data // [data1,data2,....]
})
Promise.race()
//将多个promise对象合并成一个新的promise对象
//一旦p1,p2,p3谁最先决议为 resolve或者reject那么新的promise就是 成功或者失败
let p = Promise.all([p1,p2....]);
p.then((data)=>{
  data // p1data1
})

案例






你可能感兴趣的:(ES6-promise对象)