async await 相关概念理解

先看一段代码(Vue):

methods: {
    async getAll() {
      const a = await getAllModifiedPlans()
      console.log('a;', a)
      return a
    }
},
created() {
    const result = this.getAll()
    console.log('r:', result)
}

直接调用 this.getAll(),我们期望返回 a 的值,但实际不是这样的结果

这里注意几个概念:
1. async 函数的返回值是一个 promise
2. async 里面的 return 值不是给外部的返回值,而是 promise 的 resolved 值
3. await promise 得到 resolved 值

methods: {
    async getAll() {
      const a = await getAllModifiedPlans()
      console.log('a:', a)
      return a
    }
  },
  created() {
    const result = this.getAll()
    console.log('r:', result)
  }

输出:

r: Promise {<pending>}
a: {code: 0, message: "success", data: Array(2)}

可以看到 result 会立刻得到一个 promise

解决:
methods: {
    async getAll() {
      return await getAllModifiedPlans()
    }
  },
  async created() {
    const result = await this.getAll()
    console.log(result)
  }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值