vue中异步请求数据,异步请求还没完成,文件就执行了就会报错,怎么解决?
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')
就是空导致报错,请问这个问题怎么解决?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(4)
使用bus监听一下login的结果。或者在api.js的getList()加载的时候加个定时器,去判断
localStorage.getItem('Authorization')
的值是否为空,为空就不执行,不为空就执行getList(),然后清除定时器。你可以利用axios和请求拦截器和响应拦截器来做处理
2.响应拦截器:每一次收到响应时重新赋值localStorage中的token
解决
Authorization
的请求全部放在login之后执行即可原因
js
是单线程执行的login
和getList
都是异步请求之前代码的执行顺序如下
修改代码的执行顺序如下(这时候就确保在执行getlist的时候有权限信息了)
原理
promise
了,应该对回调地狱比较了解我知道了,可以用函数来实现,因为函数执行是实时的
就像使用
应该使用函数包装起来,实时调用,这样才不会因为文件加载顺序而出现window.web3未定义的错误,