再看那柔弱的柳树吧,在寒冬余威尚盛时节,就早早苏醒过来,望着冰冻的河面,迎着凛冽的寒风,它微微察觉出一丝春意,于是,不顾一切地率先吐翠,淡淡地披起娇黄嫩绿的新装。沿河望去,枝梢间烟纱雾彀,一片生机,这情景仿佛一首动人的歌,一首热烈向往春天的歌,一首报告春的信息的歌,一首表达美好信念的歌。我在想:既然迎春花被人称作报春花,那么,柳树可不可以叫作报春树呢春来了,万千柳枝在春风中袅袅舞动。柳树是热爱春天的,春天也是热爱柳树的。
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>
总结
以上所述是小编给大家介绍的JS中async/await实现异步调用的方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
到此这篇关于JS中async/await实现异步调用的方法就介绍到这了。生活就像海洋,只有意志坚强的人,才能到达彼岸。更多相关JS中async/await实现异步调用的方法内容请查看相关栏目,小编编辑不易,再次感谢大家的支持!