一、async,await的特点
**async/ await来发送异步请求,从服务端获取数据,代码很简洁,同时async/await 已经被标准化**
特点:
▲asayc的用法,它作为一个关键字放到函数前面,这样普通函数就变为了异步函数
▲异步async函数调用,跟普通函数的使用方式一样
▲异步async函数返回一个promise对象
▲async函数配合await关键字使用(阻塞代码往下执行)
是异步方法,但是阻塞式的
async/await的优点:
★方便级联调用:即调用依次发生的场景;
★同步代码编写方式: Promise使用then函数进行链式调用,一直点点点,是一种从左向右的横向写法;async/await从上到下,顺序执行,就像写同步代码一样,更符合代码编写习惯;
★多个参数传递: Promise的then函数只能传递一个参数,虽然可以通过包装成对象来传递多个参数,但是会导致传递冗余信息,频繁的解析又重新组合参数,比较麻烦;async/await没有这个限制,可以当做普通的局部变量来处理,用let或者const定义的块级变量想怎么用就怎么用,想定义几个就定义几个,完全没有限制,也没有冗余工作;
★同步代码和异步代码可以一起编写: 使用Promise的时候最好将同步代码和异步代码放在不同的then节点中,这样结构更加清晰;async/await整个书写习惯都是同步的,不需要纠结同步和异步的区别,当然,异步过程需要包装成一个Promise对象放在await关键字后面;
★sync/await是对Promise的优化: async/await是基于Promise的,是进一步的一种优化,不过在写代码时,Promise本身的API出现得很少,很接近同步代码的写法;
使用场景
async主要来处理异步的操作,
需求:
执行第一步,将执行第一步的结果返回给第二步使用。
在ajax中先拿到一个接口的返回数据,
后使用第一部返回的数据执行第二步操作的接口调用,达到异步操作。
async/ await案例:
首先把 getFaceResult 转化成一个async 函数,就是在其前面加async, 因为它的调用方法和普通函数的调用方法是一致,所以没有什么问题。然后就把 getLocation 和getFaceList 放到await 后面,等待执行, getFaceResult 函数修改如下
async getFaceResult () {
let location = await this.getLocation(this.phoneNum);
if (location.data.success) {
let province = location.data.obj.province;
let city = location.data.obj.city;
let result = await this.getFaceList(province, city);
if (result.data.success) {
this.faceList = result.data.obj;
}
}
}