网络请求 async 与 await---产品列表渲染

在 JavaScript 中曾学过用 fetch 请求数据,比如一个显示某公司信息的 API:

{
   
  "company": "M厂",
  "slogan": "XXXXXXXX"
}

用fetch 请求数据的代码如下:

fetch(
  'https://www.XXXXXXX'
)
  .then(function(response) {
   
    return response.json();
  })
  .then(function(myJson) {
   
    console.log(myJson);
  });

由于 fetch 返回的是一个 Promise 对象,所以我们在请求数据的时候用了 then 采用平铺式回调的方式,允许我们在数据返回之后再对数据进行 response.json() 处理。

这里就有一个问题,因为 Promise 对象的一个特点是无等待,所以想对返回的数据进行操作,就必须在 then 里处理。假设一个业务,分多个步骤完成,每个步骤都是异步的,而且依赖于上一个步骤的结果。那么 then 链就会很长

异步编程终级解决方案 —— async和await。

“异步” async

async 是“异步”的简写,用于申明一个异步 function,而这个 async 函数返回的是一个 Promise 对象。

async function asyncFn() {
  return {
    "company": "M厂",
    "slogan": "XXXXXX"
  };
}

co
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值