async 函数表示这个函数内部有异步请求,如果这个 async 函数没有返回值,那么这个 async 仅仅只是一个标识而已.
await 需要结合 async 函数一起使用,它通常用于等待一个 Promise 函数或 async 函数的执行(你当然可以写个await 123,但这不会有任何作用)
先看代码
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 函数如果没有返回值则这仅仅只是一个标识,那么如果有返回值呢?
async function get() {
return 123;
}
const f = get(); // Promise { 123 }
上面代码可以看出 async 函数返回了一个 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
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思想.很方便判断是否出错.
本文作者:Yune_Neko
本文链接:https://www.cnblogs.com/UmaruChan/archive/2022/01/17/15813287.html
虽然大家知道async/await,但是很多人对这个方法中内部怎么执行的还不是很了解,本文是我看了一遍技术博客理解 JavaScript 的 async/await
Async实际上是一个封装了自动化执行并返回一个Promise的Generator函数的语法糖。这句话的意思我们可以分为三个部分来解读:首先它有一个自动化执行,Generator函数是依靠不停的调用.net来依次执行的,Async有一个自动化执行的过程
Node.js7.6起, Node.js 搭载了有async函数功能的V8引擎。当Node.js 8于10月31日成为LTS版本后,我们没有理由不使用async函数。接下来,我将简要介绍async函数,以及如何改变我们编写Node.js应用程序的方式。
自2015年11 发布1.7版以来,TypeScript 已支持 async/await 关键字。编译器使用 yield 将异步函数转换为生成器函数。这意味着咱们无法针对 ES3 或 ES5,因为生成器仅在 ES6 中引入的。
async/await 大家肯定都用过,在处理异步操作的时候真的是很方便。那今天主要讲一些在使用 async/await 时容易忽略和犯错的地方。上面的代码中,每一行都会 等待上一行的结果返回后才会执行。
有一个图片列表,我想要在图片onload成功之后获取加载成功的图片列表,图片资源加载为异步,我们使用ES7的async await方式实现,多张图片,是用for循环。
Async 和 Awaiit 是 Promise 的扩展,我们知道 JavaScript 是单线程的,使用 Promise 之后可以使异步操作的书写更简洁,而 Async 使 Promise 像同步操作
最近代码写着写着,我突然意识到一个问题——我们既然已经有了 Promise 和 then,为啥还需要 async 和 await?这不是脱裤子放屁吗?
如果让你手写async函数的实现,你是不是会觉得很复杂?这篇文章带你用20行搞定它的核心。经常有人说async函数是generator函数的语法糖,那么到底是怎么样一个糖呢?让我们来一层层的剥开它的糖衣。
async/await是ES7的写法,可以让非同步call back写法看起来像同步的顺序去执行。以下我们new一个Promise的class并return给一个function
内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!