首先,我们为什么要用Promise语法?
Promise作为替代回调函数执行,作为异步操作的处理方法之一,是解决JS异步执行时候回调函数嵌套回调函数这一问题的方法,它更简洁地控制函数执行流程
一般promise有三种状态:pending(等待态),fulfiled(成功态),rejected(失败态);
常见写法为:
let p = new Promise(resolve, reject){}.then();
通常,我们处理异步请求,会使用回调函数嵌套回调函数
例如:
fn("a", function(a) {
fn1("b", function(b) {
fn2("c", function(c) {
fn3("d", function(d) {
alert("回调成功,结果为:"a+b+c+d")
})
})
})
})
但我们发现这样写的代码可读性并不高
如果使用promise语法,则更加符合阅读习惯,只需要在then函数中写处理逻辑即可
new Promise(function(resolve , reject) {
resolve(1);
}).then(function(val) {
console.log(val);
return new Promise(function(resolve , reject) {
resolve(2);
});
}).then(function(val) {
console.log(val);
return new Promise(function(resolve , reject) {
resolve(3);
});
}).then(function(val) {
console.log(val);
return new Promise(function(resolve , reject) {
resolve(4);
});
}).then(function(val) {
console.log(val);
});
运行结果为:
接下来模拟在实际项目开发中,在异步请求完数据后处理数据的情况,我们在这里用settimeout来模拟异步请求
let mypromise = new Promise(function(resolve, reject){
setTimeout(function(){
resolve("成功!");
}, 1000);
});
mypromise.then(function(successMessage){
console.log(successMessage);
});
运行结果为:
我们可以看到这里的“成功!”在运行一秒后执行
常用API
(1) new Promise
new Promise(function(resolve, reject){
});
(2) PromiseObj.then(resolveFn,rejectFn)
resolveFn:Promise对象成功的回调处理函数
rejectFn:Promise对象失败的回调处理函数
new Promise((resolve,reject)=>{
}).then((resolveData)=>{
},(rejectErr)=>{
})
(3) PromiseObj.catch()
new Promise((resolve,reject)=>{
}).catch(err=>{
console.log(err)
})
(4)PromiseObj.resolve()
Promise.resolve(123).then(data=>{
console.log(data)
})
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。