为了账号安全,请及时绑定邮箱和手机立即绑定

vue中异步请求数据,异步请求还没完成,文件就执行了就会报错,怎么解决?

vue中异步请求数据,异步请求还没完成,文件就执行了就会报错,怎么解决?

一只斗牛犬 2019-02-26 20:03:35
vue中,axios异步加载数据,但是有的文件里面需要用到异步拿到的数据,数据还没拿到,文件已经执行了,这时候数据就是空,就会报错,这个问题怎么解决?具体表现:我这边vue项目是进入页面的时候会调用一个login方法,然后设置localStorage,this.login().then(res => {    if (res.code === 0) {         localStorage.setItem(res.data.access_token)     } });然后有一个api.js文件,使用的是axios方法const instance = axios.create({    baseURL: config.BASE_URL,    headers: {        Authorization: localStorage.getItem('Authorization') || ''     } });export default {     getList() {        return instance.request({            url: '123',            method: 'get'         })     } }但是因为login方法还没执行完api.js文件就已经执行了,所以localStorage.getItem('Authorization')就是空导致报错,请问这个问题怎么解决?
查看完整描述

2 回答

?
狐的传说

TA贡献1804条经验 获得超3个赞

我知道了,可以用函数来实现,因为函数执行是实时的
就像使用

const SaleClockAuctionContract = window.web3.eth.contract(SaleClockAuction.abi).at(SaleClockAuction.address);const KittyCoreContract = window.web3.eth.contract(KittyCore.abi).at(KittyCore.address);

应该使用函数包装起来,实时调用,这样才不会因为文件加载顺序而出现window.web3未定义的错误,

const SaleClockAuctionContract = () => {    window.web3.eth.contract(SaleClockAuction.abi).at(SaleClockAuction.address);
}const KittyCoreContract = () => {    window.web3.eth.contract(KittyCore.abi).at(KittyCore.address);
}


查看完整回答
反对 回复 2019-02-26
  • 2 回答
  • 0 关注
  • 1820 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信