如何解决vuex数据异步造成初始化时没值报错的问题

这篇文章主要介绍如何解决vuex数据异步造成初始化时没值报错的问题,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

当使用vue做登录的时候,我们会把拿到的部分用户信息存在vuex+cookie中,我们知道,vuex的数据是会随着浏览器刷新而丢失的,此时我们会重新请求接口对vuex的数据进行再次赋值,如下

当有cookie但是vuex没有数据的时候再次请求赋值

如何解决vuex数据异步造成初始化时没值报错的问题

state

如何解决vuex数据异步造成初始化时没值报错的问题

mutation

如何解决vuex数据异步造成初始化时没值报错的问题

vuex的数据是异步的,当我们页面需要直接拿vuex的值进行渲染的时候,初始化瞬间(即请求过程进行的时候),vuex是没有这个值的,如何解决这个问题,暂时总结了三种方法,希望有遇到的大佬进行补充和查错:

1.通过watch和mouted监听并且初始化vuex数据

在mounted的时候初始化该数据 并且watch该数据(不推荐)

2.在computed赋值该数据 并且在dom渲染的时候做非空的判断

如何解决vuex数据异步造成初始化时没值报错的问题

如何解决vuex数据异步造成初始化时没值报错的问题

或者:

如何解决vuex数据异步造成初始化时没值报错的问题

如何解决vuex数据异步造成初始化时没值报错的问题

3.使用拓展运算符

如何解决vuex数据异步造成初始化时没值报错的问题

以上是“如何解决vuex数据异步造成初始化时没值报错的问题”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注行业资讯频道!