promise
概念:Promise 对象用于表示一个异步操作的最终完成 (或失败)及其结果值。
新建一个promise对象
new Promise(function(req,res){
//要做的事情
})
实例:分三次输出字符串,第一次间隔1秒,第二次间隔4秒,第三次间隔3秒
//普通实现效果
setTimeout(function(){
console.log("First")
setTimeout(function(){
console.log("Second")
setTimeout(function(){
console.log("Third")
},3000)
},4000)
},1000)
//用promise实现同样的功能
new Promise(function(resolve,reject){
setTimeout(function(){
console.log("First")
resolve()
},1000)
}).then(function(){
return new Promise(function(resolve,reject){
setTimeout(function(){
console.log("Second")
resolve()
},4000)
})
}).then(function(){
setTimeout(function(){
console.log("Third")
},3000)
})
注意:
- Promise构造函数只有一个参数,是一个函数,这个函数在构造之后就直接被异步运行,所以我们称之为起始函数。起始函数包含两个参数resolve和reject(当Promise被构造时,起始函数被异步执行)
- resolve和reject都是函数,其中调用resolve代表正常,reject是出现异常时调用的
- Promise类有.then .catch 和finally()三个方法,这三个方法的函数都是一个参数,
.then()可以将参数中的函数添加到当前Promise的正常执行序列
.catch()设定Promise的异常处理序列
.finally()是Promise执行的最后一定会执行的序列
(then()传入的函数会按顺序依次执行,有任何异常会直接调到catch序列) - resolve 和 reject 的作用域只有起始函数,不包括 then 以及其他序列;
- resolve 和 reject 并不能够使起始函数停止运行,别忘了 return。
Async和Await
概念:async是es7才有的与异步操作有关的关键字,和Promise,Generator有很大关系
- async函数返回一个Promise对象,可以使用then方法添加回调函数
async function a(){
return "hellow"
}
console.log(a()) //Promise { 'hellow' }
a().then (v => {
console.log(v);
}) //hellow
- async函数中可能会有await表达式,async函数在执行时,如果与遇到await就会暂停执行,等触发的异步操作完成后,恢复async函数的执行并返回解析值
- await关键字仅在async function中有效。如果在async function函数体外使用await,会得到一个语法错误
function testAwait(){
return new Promise((resolve) => {
setTimeout(function(){
console.log("testAwait");
resolve();
}, 1000);
});
}
async function helloAsync(){
await testAwait();
console.log("helloAsync");
}
helloAsync();
// testAwait
// helloAsync
- 正常情况下,await命令后面是一个Promise对象,它也可以跟其他值,如字符串,布尔值,数值以及普通函数
- await针对所跟不同表达式的处理方式:
- Promise对象:await会暂停执行,等待Promise对象resolve,然后恢复async函数的执行返回解析值
- 非Promise对象:直接返回对应的值*
本文深入探讨了Promise对象在处理异步操作中的作用,通过实例展示了如何创建和使用Promise实现异步任务的顺序执行。接着,我们介绍了ES7引入的async/await关键字,它简化了Promise的使用,使得异步代码更加清晰和易于理解。通过示例,解释了async函数返回Promise以及await如何暂停执行直到异步操作完成。文章还提及了await只能在async函数内部使用,并且可以等待不同类型的值,如Promise对象和其他基本类型值。
2954

被折叠的 条评论
为什么被折叠?



