建议收藏:async 与 await的理解 ,浅析 promise 的理解
async
函数表示这个函数内部有异步请求,如果这个 async 函数没有返回值,那么这个 async 仅仅只是一个标识而已.
await
需要结合 async 函数一起使用,它通常用于等待一个 Promise 函数或 async 函数的执行(你当然可以写个await 123
,但这不会有任何作用)
1 2 3 4 5 6 7 8 9 10 11 12 | console.log(1); (async function () { console.log(2); const res = await req(); // 随意定义一个返回值是Promise的函数 console.log(3); if (res[0]) { throw new Error(res[0]); } else { console.log( "请求成功" ); } })(); console.log(4); |
如果对 Promise 很了解的话,应该很快能看出控制台的输出顺序是 1 2 4 3 "请求成功",如果你判断错误了也没关系,实际开发中多用用就熟悉了.笔者也经常会判断失误.
async 函数返回了一个 Promise 对象.
1 2 3 4 5 6 | async function get() { return 123; } const f = get(); // Promise { 123 } f是一个promise对象 |
作用就是你可以不用再在一个函数里手写return new Promise((resolve, reject)=>{})
了,可以直接返回一个 async 函数
要注意的是在 Promise 中是使用resolve()
返回正常值,reject()
返回异常值
在 async函数
中使用return
返回正常值,使用抛出错误throw new Error()
返回异常值
function (a,b) { return async function () { const res = await getSomething({a,b}); if (res.code === 200) { return [res.data.rows]; } else { throw new Error(res.msg); } }; } |
抛出错误那势必就要处理错误.而处理错误的方式也是有好几种的,
我只在这里写我推荐的 Error First
思想, 另一个方法是传统的 try catch
1 2 3 4 5 6 7 8 9 10 | async function sendReq() { const res = await getSomething().then((res) => [ null , res]). catch ((error) => [error, null ]); if (res[0] !== null ) { // 错误逻辑 console.error(error); return ; } // 正确逻辑 console.log(res[1]); } |
上面的代码,在 await 函数后面加上.then().catch()
,在学习Promise的时候,我们知道Promise的then方法是处理resolve,then后的catch方法是处理reject,
并且这两个也都会返回一个Promise,因此再使用await接收then或catch返回的Promise即可.
返回的值为一个数组,发生错误的时候把错误放到数组的第一位,这种思想称之为Error First
思想.很方便判断是否出错.
分类:
JavaScript
, es6
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具