async 和 await 初步小用法

async 和 await 初步小用法

项目中需要把ajax获取数据的方法封装起来,没用await之前这样写的

export function getDataSuc(jsondata,activeproject,km){
	var datas = []
	axios.get(jsondata, {
		params: {
			activeproject: activeproject,
			km:km
		}
	}).then(res=>{
		datas = res.data.data
		console.log(datas)    // 2
	})
	console.log(datas)     // 1
	return datas
}

发现方法返回的datas是空值,2处能输出值,1处输出的是空值,应该是ajax异步获取数据的原因,而且在控制器里能看到,是先输出1处的值,再输出2处的。
用了await和async之后的代码:

async function getDatas(jsondata,activeproject,km) {
	return axios.get(jsondata, {
		params: {
			activeproject: activeproject,
			km:km
		}
	})
}

export async function getDataSuc(jsondata,activeproject,km) {
	try {
		let datas = await getDatas(jsondata,activeproject,km).then(res => {
			return Promise.resolve(res.data.data)
		})
		return datas
	} catch (e) {
		console.log(e)
	}
}

页面获取return值的方法:

this.list = await util.getDataSuc('/api/zhibo.json',activeproject,km)

这样list就可以获取getDataSuc()返回的值

tips: async返回的是Promise对象;而await等待的就是async函数完成,但await等待的可以是Promise对象或者其他任意表达式的结果

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值