最近在写代码的时候遇到了异步请求的问题,在这里呢,我想到了应用es6的async await
async函数是在ES2017引入的,它主要是让异步操作变得更加方便,他的用法是作为关键字放到函数面前,表示这个函数是一个异步方法,异步方法就是不用管这个方法,会继续往下走,不会阻塞下面js代码的执行
async函数返回的是一个promise对象,如果想要获取peomise返回值,需要用then方法
await是依附于async的,它的作用就相当于它的字面意思,等一下,就是等着我返回结果以后,再继续走下去。
举个例子
看下输出结果
结果分析:因为firstMethod是异步方法,所以,会先执行console.log(data),接着走下面的定时器,输出“我应该后执行”,然后执行 firstMethod,输出“我应该先执行”
下面我们改造成async函数
结果分析:
await那里代表着必须先等待firstMethod执行完毕,才能继续往下走,所以输出结果就是这样了