目录
回调地狱
function a(){
setTimeout(() => {
setTimeout(() => {
setTimeout(() => {
console.log("123")
}, 1000);
}, 3000);
}, 2000);
}
a()
执行上述代码,会先等2s然后执行里面的定时器,再等3s执行最里面的定时器,再等1s才会输出结果,不停的使用回调函数(将一个函数作为参数传给另一个函数),如果a函数里面有很多个定时器,那么会一直回调,称为回调地狱,而解决回调地狱的办法之一就是使用Promise
Promise
promise译为承诺,即许出一个承诺,在一定的时间后给出一个结果
Promise的三种状态
pending(等待态),fulfiled(成功态),rejected(失败态)
在承诺许出时,会进入等待态,等待承诺结果,如果兑现承诺,则会变为成功态,否则就会变为失败态
Promise的使用
使用Promise的时候要传入两个参数,resolve表示成功的回调,reject表示失败的回调
then方法也要传入两个参数,一个是成功时所要做的事,一个是失败时所要做的事,并且这两个参数会拿到resolve和reject传来的数据
let give = new Promise((resolve,reject)=>{
if(true){
resolve(123)
}
else reject()
})
give.then((data)=>{
console.log("成功"+ data)
},()=>{
console.log("失败")
})
欢迎指正