今天就跟大家聊聊有关怎么在JavaScript中使用async和await实现异步调用,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。
async/await多个函数关联调用
async/await使得异步代码看起来像同步代码
async函数会隐式地返回一个promise,而promise的reosolve值就是函数return的值
Async/Await不需要写.then,不需要写匿名函数处理Promise的resolve值,也不需要定义多余的data变量,还避免了嵌套代码
async声明一个异步函数
await只能在async函数中使用,后面跟一个promise对象
所以在模拟异步调用函数时,函数体内返回promise
async/await缺点
async函数里,无论是Promise reject的数据还是逻辑报错,都会被默默吞掉。所以最好把await放入try{}catch{}中,或者在async返回的promise对象中使用.cache捕获错误。
实现
项目中实现三个不同的接口调用,三个接口是相互关联的,前一个接口的返回值是后一个接口的参数,如果使用Promise实现的话,只能实现异步调用,但是无法相互关联,也就是数据不互通,所以使用async/await实现
接口调用的方法独立封装,参数可动态设置
async声明异步方法,内部使用await关键字调用封装的接口,参数可直接传入
async/await相当于将Promise异步调用同步化,数据可实现关联
async/await会默认返回一个Promise对象,在实际调用中使用cache捕获错误
代码实现
<script>
//再此使用定时器模拟异步接口的调用
// 异步函数a
function a() {
return new Promise(resolve => {
setTimeout(()=>{
resolve('a')
}, 1000)
})
}
// 异步函数b,关联a参数
function b(a) {
return new Promise(resolve => {
setTimeout(()=>{
resolve(a+'b')
}, 1000)
})
}
// 异步函数c,关联b参数
function c(b) {
return new Promise(resolve => {
setTimeout(()=>{
resolve(b+'c')
}, 1000)
})
}
// 同步执行三个关联的异步函数
async function d(){
const da = await a();
const db = await b(da);
const dc = await c(db);
return dc;
}
// 实际调用
d().then(res=>{
console.log(res)
}).catch(err=>{
console.log(err)
});
</script>
看完上述内容,你们对怎么在JavaScript中使用async和await实现异步调用有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注亿速云行业资讯频道,感谢大家的支持。
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。