使用async+await+promise 报错 PromiseStatus pending

6 篇文章 0 订阅
3 篇文章 0 订阅

原因,把接受数据的变量this.nav写在了调用async定义的函数外面。

错误代码

initPage: async function () {				
    let url = 'http://examp.com/api/examp';
    let params = {
		code: "",
		level: 0,
    }
    return await this.$fetch.post(url, params);  // 这样写不对			
},
this.nav = this.initPage();

此时,this.nav的结果就会显示 PromiseStatus pending

正确代码

initPage: async function () {				
    let url = 'http://examp.com/api/examp';
    let params = {
		code: "",
		level: 0,
    }
    this.nav = await this.$fetch.post(url, params);  // 关键点				
},
this.initPage();

除非使用.then()来接收结果

this.initPage().then(res => this.nav = res);

https://www.jianshu.com/p/aaef3ab70b8f

https://stackoverflow.com/questions/47259953/js-async-await-return-promise?r=SearchResults

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值