在做vue项目的过程中有时候会遇到一个问题,就是进行F5页面刷新的时候,页面的数据会丢失,出现这个问题的原因是因为当用vuex做全局状态管理的时候,store中的数据是保存在运行内存中的,页面刷新时会重新加载vue实例,store中的数据就会被重新赋值,因此数据就丢失了,解决方式如下:
方法1、利用localStorage/sessionStorage将数据储存在外部,做一个持久化储存,通过监听beforeunload事件来进行数据的localStorage存储,beforeunload事件在页面刷新时进行触发,具体做法是在App.vue的created()周期函数中下如下代码:
export default { name: 'App', created () { //在页面加载时读取localStorage里的状态信息 if (window.localStorage.getItem('list')) { //this.$store.replaceState()替换 store 的根状态 this.$store.replaceState(Object.assign({}, this.$store.state, JSON.parse(window.localStorage.getItem('list')))) } //在页面刷新时将vuex里的信息保存到localStorage里 window.addEventListener('beforeunload', () => { window.localStorage.setItem('list', JSON.stringify(this.$store.state)) }) } }
方法2:由此得知计算属性的结果会被缓存,也就是说在有缓存的情况下,computed会优先使用缓存,于是也可以在state数据相对应的页面这样写:
computed:{ orderList() { return this.$store.state.orderList } }
最新评论