当异步操作依赖于上一个异步操作的时候,需要进行异步操作的嵌套,否则无法保证回调的顺序执行。但是采用回调嵌套,会形成回调地狱。
为了解决回调地狱的问题,在ES6中新增了promise API
//新建一个承诺容器
var pi = new Promise(function(resolve,reject){
fs.readFile('./data/123.txt', 'utf8', function(err,data){
if(err){
//失败了,承诺容器中的任务失败了
//调用reject等于调用了then方法的第二个参数函数
reject(err)
//把容器的pending状态变为rejected
}else{
//承诺容器中的任务成功了
//这里调用的resolve方法实际上就是then方法传递的那个function
resolve(data)
//把容器的pending状态变为resolve
}
})
})
//当p1成功了,然后(then)做指定的动作
//then方法接受的function就是容器中的resolve函数
p1.then(function(data){
//当前函数中return的结果就可以在后面then中的function接收到
//当return 一个 Promise 对象(这里称为p2)的时候,
//后续的then中的方法的第一个参数做为p2的resolve,第二个参数作为p2的reject
return data;
},function(err){
console.log('读取文件失败了',err)
})
.then(function(data){
console.log(data)
})
首先,promise是一个容器,存放着当前任务完成后即将执行的代码,promise容器一旦创建,就开始执行里面的代码。promise不是异步的,但是内部的任务一般都是异步的。
在promise内部就会根据异步操作是否成功来调用回调方法,回调方法依赖then传入的两个参数。这样,通过在then方法的第一个参数(既当操作成功的时候会调用的方法)中return一个新的promise,然后链式调用then就可以做到嵌套异步操作又避免回调地狱的效果。