vue刷新页面,数据不丢失
在做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
}
}

浙公网安备 33010602011771号