asyncawait让异步编程更简单,全方位讲解,手把手教你能不会?

本文深入探讨了JavaScript中的async/await语法,它是基于Promise的语法糖,使得异步代码更加易读易写。async关键字用于定义异步函数,返回一个Promise,而await则用于在异步函数内部等待Promise完成。通过这种方式,开发者可以编写出类似同步的代码,而无需层层嵌套的.then()。示例展示了如何使用async/await进行文件加载和错误处理,使得代码更简洁直观。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

简单来说,async/await是基于promises的语法糖,使异步代码更易于编写和阅读。

一、async:

async创建一个异步函数来定义一个代码块,在其中运行异步代码;

怎样变成异步函数呢?以async这个关键字开始,它可以被放置在一个函数前面

async function f() {
  return 1;
}

f().then(alert); // 1

//上下结果一样

async function f() {
  return Promise.resolve(1);
}

f().then(alert); // 1

//也可以用箭头函数
let hello = async () => { return "1" };
hello().then((value) => console.log(value))
//返回值也可以简化成这样
hello().then(console.log)

异步函数的特征之一:保证函数的返回值为 promise。

async关键字加到函数申明中,可以告诉它们返回的是 promise,而不是直接返回值。此外,它避免了同步函数为支持使用await带来的任何潜在开销。

二、await:

await只在异步函数里面才起作用。它可以放在任何异步的,关键字await让 JavaScript 引擎等待直到 promise 完成并返回结果。在等待promise的同时,其他正在等待执行的代码就有机会执行了。

您可以在调用任何返回Promise的函数时使用await,包括Web API函数。

async function f() {
  let promise = new Promise((resolve, reject) => {
    setTimeout(() => resolve("咚!"), 1000)
  });

  let result = await promise; // 等待执行,直到 promise resolve 执行完

  alert(result); // "咚!"
}

f();//拿到 result 作为结果继续往下执行。所以上面这段代码在1秒后显示 “咚!”。

注意:await实际上会暂停函数的执行,直到 promise 状态变为 完成,然后以 promise 的结果继续执行。这个行为不会耗费任何 CPU 资源,因为 JavaScript 引擎可以同时处理其他任务:执行其他脚本,处理事件等。

三、综合应用:

有了async/await就去除了到处都是.then()代码块,因为await会等待了。

async function A() {
  let response = await fetch('c.jpg');
  let myBlob = await response.blob();

  let objectURL = URL.createObjectURL(myBlob);
  let image = document.createElement('img');
  image.src = objectURL;
  document.body.appendChild(image);
}

A()
.catch(e => {
  console.log('问题: ' + e.message);
});

用更少的.then()块来封装代码,同时它看起来很像同步代码,所以它非常直观。这样用的很爽!

想了解更多常用异步?点击下列蓝色字体学习哦!

1.Promise如何使用?全方位解析,一篇搞懂异步

2.让你五分钟搞懂,错误处理try…catch…finally的文章,涵盖throw,TypeError,RangeError,SyntaxError解释

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值