async和await的使用

async和await是promise的一种语法糖,也就是更简单易懂的写法。

在很多项目中,你会经常看到async和await的配合使用,看到原始的promise写法反而不多,就是因为async-await这种写法是用同步的语法去实现异步的逻辑。

基础使用

原生promise写法

javascript 复制代码
        let value = null
        let proFn = new Promise((resolve,reject)=>{
            setTimeout(()=>{
              resolve('成功的值')
            },2000)
        })
        proFn.then(res=>{
            value = res
            console.log(value,'异步返回值')
            //...value获取到了值,可以处理后续的业务逻辑
        })

async和await的写法

javascript 复制代码
        let proFn = ()=>{
            return new Promise((resolve, reject) => {
            setTimeout(() => {
                resolve('成功的值')
            }, 2000)
        })
        } 
        async function getVal(){
            let value = await proFn() //这条语句执行完毕,后续的代码都需要等value获取到了promise返回的值,才会开始去执行
            console.log(value,'获取到了值')
            //...可以执行后续的业务
        }
        getVal()

两者执行结果都是一样的

async

作用

async需要在函数上使用,本质是Generator 函数的语法糖。

一旦某个函数使用了async,那么这个函数的返回值就会被包装成一个promise函数

javascript 复制代码
        let fn = async function(){
            return '函数返回值'
        }
        console.log(fn(),'调用fn函数')
        fn().then(res=>{
            console.log(res,'获取值')
        })

语法

async写在函数定义的时候,可以有如下写法

javascript 复制代码
        let fn1 = async function(){
            return '普通函数1'
        }
        async function fn2(){
            return '普通函数2'
        }
        async ()=> '箭头函数'
        class Fn{
            constructor(){

            }
            async fn(){
                return '类中的方法'
            }
        }

await

使用条件

await是不可以单独去使用的,是需要和async函数去配合使用的

javascript 复制代码
        let pro = function(){
            return new Promise(res=>{
                res('成功的值')
            })
        }
        let value = await pro()

参数类型

await命令后面可以绑定两种类型的参数,一种是常规类型,一种是promise类型

javascript 复制代码
        let pro = async function(){
            let value = await '常规值'
            console.log(value,'await返回常规值')
        }
        pro()
javascript 复制代码
        let pro = async function(){
            let value = await new Promise(res=>{
                setTimeout(()=>{
                    res('promise执行成功的值')
                },3000)
                
            })
            console.log(value,'await绑定promise实例')
        }
        pro()

处理错误

async-await在处理错误时,可以使用try catch语法配合

javascript 复制代码
        async function pro(){
            try{
               let value =  await new Promise((resolve,reject)=>{
                setTimeout(()=>{
                    // resolve('成功')
                    reject('失败')
                },3000)
            })
            return value
        
            }catch(error){
              console.log(error,'进入catch')
              return error
            }

        }
        pro().then(res=>{
            console.log(res,'执行完毕')
        }).catch(error=>{
            console.log(error,'报错回调')
        })
相关推荐
竹林8188 小时前
在NFT项目中集成IPFS:从Pinata上传到前端展示的完整踩坑指南
前端·javascript
吴声子夜歌8 小时前
Vue3——渲染函数
前端·vue.js·vue·es6
Hello--_--World8 小时前
ES15:Object.groupBy() 和 Map.groupBy()、Promise.withResolvers() 相关知识点
开发语言·前端·javascript
Cache技术分享8 小时前
386. Java IO API - 监控目录变化
前端·后端
Hooray8 小时前
管理后台框架 AI 时代的版本答案,Fantastic-admin 6.0 它来了!
前端·前端框架·ai编程
2501_913680009 小时前
Vue3项目快速接入AI助手的终极方案 - 让你的应用智能升级
前端·vue.js·人工智能·ai·vue·开源软件
开开心心_Every9 小时前
动图制作工具,拆分转视频动态照离线免费
运维·前端·人工智能·edge·pdf·散列表·启发式算法
饭后一颗花生米9 小时前
2026 前端实战:AI 驱动下的性能优化与工程化升级
前端·人工智能·性能优化
YJlio9 小时前
4月14日热点新闻解读:从金融数据到平台治理,一文看懂今天最值得关注的6个信号
java·前端·人工智能·金融·eclipse·电脑·eixv3
xjf77119 小时前
AI重构前端项目指南
前端·ai·重构·编程