◼ async关键字用于声明一个异步函数:
async是asynchronous单词的缩写,异步、非同步;
sync是synchronous单词的缩写,同步、同时;
◼ async异步函数可以有很多中写法
async function foo(){}
const foo1 = async function(){}
const foo2 = async ()=>{}
class Person{
async foo(){}
}
异步函数的执行流程
◼ 异步函数的内部代码执行过程和普通的函数是一致的,默认情况下也是会被同步执行。
◼ 异步函数有返回值时,和普通函数会有区别:
情况一:异步函数也可以有返回值,但是异步函数的返回值相当于被包裹到Promise.resolve中;
情况二:如果我们的异步函数的返回值是Promise,状态由会由Promise决定;
情况三:如果我们的异步函数的返回值是一个对象并且实现了thenable,那么会由对象的then方法来决定;
◼ 如果我们在async中抛出了异常,那么程序它并不会像普通函数一样报错,而是会作为Promise的reject来传递;
异步函数的返回值
function foo1(){
}
foo1()
async function foo2() {
return{
then:function(resolve,reject){
setTimeout(()=>{
resolve("bbb")
},3000)
}
}
}
foo2()
foo2().then(res=>{
console.log(res)
})
异步函数的reject或者出现异常
async function foo() {
console.log("111111111111")
console.log("222222222222")
throw new Error("hdc:出错了")
console.log("333333333333")
return 123
}
foo().then(res=>{
console.log(res)
}).catch(err=>{
console.log(err)
})
await关键字
◼ async函数另外一个特殊之处就是可以在它内部使用await关键字,而普通函数中是不可以的。
◼ await关键字有什么特点呢?
通常使用await是后面会跟上一个表达式,这个表达式会返回一个Promise;
那么await会等到Promise的状态变成fulfilled状态,之后继续执行异步函数;
◼ 如果await后面是一个普通的值,那么会直接返回这个值;
◼ 如果await后面是一个thenable的对象,那么会根据对象的then方法调用来决定后续的值;
◼ 如果await后面的表达式,返回的Promise是reject的状态,那么会将这个reject结果直接作为函数的Promise的reject值;
function bar(){
console.log("bar() 函数执行")
return new Promise((resolve,reject)=>{
setTimeout(()=>{
resolve(123)
},100000)
})
}
async function foo(){
console.log("------------")
const res = await bar()
console.log("await后续代码",res)
console.log("++++++++++++")
}
foo()
await 和async结合使用
function hdc(url){
return new Promise((resolve,rejdect)=>{
setTimeout(()=>{
resolve(url)
},2000)
})
}
async function test(){
console.log("test 函数")
return "test"
}
async function bar() {
console.log("bar 函数")
return new Promise((resolve)=>{
setTimeout(()=>{
resolve("bar")
},2000)
})
}
async function demo() {
console.log("demo函数")
return{
then:function(resolve){
resolve("demo")
}
}
}
async function foo() {
const res1 = await hdc("hdc")
console.log("res1",res1)
const res2 = await test()
console.log("res2",res2)
const res3 = await bar()
console.log("res3",res3)
const res4 = await demo()
console.log("res4",res4)
}
foo()
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!