js中async-await关键字

一、async-await

1.async-await 关键字是promise的语法糖,这个语法糖主要优化掉的是promise的then回调函数语法
2.async 主要作用使用来定义特殊函数(用async定义的函数内部可以使用await关键字),await 主要用来替代then回调函数,await 最主要的作用就是获取promise对象状态改变时传递的数据
3.async函数返回值是一个Promise对象

二、代码解释

foo函数是async函数,内部使用await语法,获取p状态变为成功时携带的数据,foo函数有return值,返回一个promise对象,所以p2是一个promise对象,通过p2.then可以获得foo函数的返回值

let p = new Promise((resolve, reject) => {
  setTimeout(function () {
    resolve("promise success");
  }, 1000);
});

async function foo() {
  let data = await p;
  console.log(data); // "promise success"
  return "async-await success";
}

let p2 = foo();
p2.then(function (res) {
  console.log(res); // async-await success
});
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值