分享web开发知识

注册/登录|最近发布|今日推荐

主页 IT知识网页技术软件开发前端开发代码编程运营维护技术分享教程案例
当前位置:首页 > 代码编程

JS学习- ES6 async await使用

发布时间:2023-09-06 02:30责任编辑:沈小雨关键词:暂无标签

async 函数是什么?一句话,它就是 Generator 函数的语法糖。

使用场景常常会遇到,请求完一个接口,拿完值再去请求另外一个接口,我们之前回调callback函数处理,如果很多的情况下,看起来很冗余,这时我们可以用async函数。

比如我们有两个请求,如下,这里用的axios:

function getCode(){ ?????return axios.get(‘json/code.json‘); ?} function getlist(params){ ?????return axios.get(‘json/person.json‘,{params}) ?}

我们第二个请求获取列表的时候需要使用第一个请求得到的code值,只有code值为0时,才能请求,而且当做参数传进去,那么我们看一下常规的做法吧

function getFinal(){ ?????console.log("我是getFinal函数") ?????getCode().then(function(res){ ????????if(res.data.code == 0){ ??????????????console.log(res.data.code); ????????????????var params = { ?????????????????????code:res.data.code ?????????????????} ??????????????getlist(params).then(function(res){ ???????????????????if(res.data.code == 0){ ????????????????????????console.log(res.data.list); ??????????????????????} ??????????????????}) ???????????????} ?????????}) ?????} ?getFinal();

来一个async await的写法

async function getResult(){ ???????????console.log("我是getResult函数") ???????????let code = await getCode(); ???????????console.log(code.data.code); ???????????if(code.data.code == 0){ ???????????????var params = { ???????????????????code:code.data.code ???????????????} ???????????????let list = await getlist(params); ???????????????console.log(list.data.list); ???????????} ???????}getResult();

处理异常,可以加上try catch

async function getResult(){ ???????????console.log("我是getResult函数") ???????????try{ ???????????????let code = await getCode(); ???????????????console.log(code.data.code); ???????????????if(code.data.code == 0){ ???????????????????var params = { ???????????????????????code:code.data.code ???????????????????} ???????????????????let list = await getlist(params); ???????????????????console.log(list.data.list); ???????????????} ???????????}catch(err){ ???????????????console.log(err); ???????????} ???????}getResult();

 

基本用法:

返回promise对象 

有时,我们希望即使前一个异步操作失败,也不要中断后面的异步操作。这时可以将第一个 await 放在 try...catch 结构里面,这样不管这个异步操作是否成功,第二个 await 都会执行。

async function f() { ?try { ???await Promise.reject(‘出错了‘); ?} catch(e) { ?} ?return await Promise.resolve(‘hello world‘);}f().then(v => console.log(v))// hello world

如果有多个 await 命令,可以统一放在 try...catch 结构中。

async function main() { ?try { ???const val1 = await firstStep(); ???const val2 = await secondStep(val1); ???const val3 = await thirdStep(val1, val2); ???console.log(‘Final: ‘, val3); ?} ?catch (err) { ???console.error(err); ?}}

  

JS学习- ES6 async await使用

原文地址:https://www.cnblogs.com/yangsg/p/10270717.html

知识推荐

我的编程学习网——分享web前端后端开发技术知识。 垃圾信息处理邮箱 tousu563@163.com 网站地图
icp备案号 闽ICP备2023006418号-8 不良信息举报平台 互联网安全管理备案 Copyright 2023 www.wodecom.cn All Rights Reserved