理解
* 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
})
案例