经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » JS/JS库/框架 » JavaScript » 查看文章
async await的理解
来源:cnblogs  作者:Yune_Neko  时间:2022/1/17 16:14:25  对本文有异议

初识

async 函数表示这个函数内部有异步请求,如果这个 async 函数没有返回值,那么这个 async 仅仅只是一个标识而已.

await 需要结合 async 函数一起使用,它通常用于等待一个 Promise 函数或 async 函数的执行(你当然可以写个await 123,但这不会有任何作用)

先看代码

  1. console.log(1);
  2. (async function () {
  3. console.log(2);
  4. const res = await req(); // 随意定义一个返回值是Promise的函数
  5. console.log(3);
  6. if (res[0]) {
  7. throw new Error(res[0]);
  8. } else {
  9. console.log("请求成功");
  10. }
  11. })();
  12. console.log(4);

如果对 Promise 很了解的话,应该很快能看出控制台的输出顺序是 1 2 4 3 "请求成功",如果你判断错误了也没关系,实际开发中多用用就熟悉了.笔者也经常会判断失误.

进阶

上面说到 async 函数如果没有返回值则这仅仅只是一个标识,那么如果有返回值呢?

  1. async function get() {
  2. return 123;
  3. }
  4. const f = get(); // Promise { 123 }

上面代码可以看出 async 函数返回了一个 Promise 对象.

作用就是你可以不用再在一个函数里手写return new Promise((resolve, reject)=>{})了,可以直接返回一个 async 函数

要注意的是在 Promise 中是使用resolve()返回正常值,reject()返回异常值

async函数 中使用return返回正常值,使用抛出错误throw new Error()返回异常值

  1. function (a,b) {
  2. return async function () {
  3. const res = await getSomething({a,b});
  4. if (res.code === 200) {
  5. return [res.data.rows];
  6. } else {
  7. throw new Error(res.msg);
  8. }
  9. };
  10. }

处理异常

抛出错误那势必就要处理错误.而处理错误的方式也是有好几种的,我只在这里写我推荐的 Error First 思想, 另一个方法是传统的 try catch

  1. async function sendReq() {
  2. const res = await getSomething().then((res) => [null, res]).catch((error) => [error, null]);
  3. if (res[0] !== null) {
  4. // 错误逻辑
  5. console.error(error);
  6. return;
  7. }
  8. // 正确逻辑
  9. console.log(res[1]);
  10. }

上面的代码,在 await 函数后面加上.then().catch(),在学习Promise的时候,我们知道Promise的then方法是处理resolve,then后的catch方法是处理reject,并且这两个也都会返回一个Promise,因此再使用await接收then或catch返回的Promise即可.

返回的值为一个数组,发生错误的时候把错误放到数组的第一位,这种思想称之为Error First思想.很方便判断是否出错.

原文链接:http://www.cnblogs.com/UmaruChan/p/15813287.html

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号