加入收藏 | 设为首页 | 会员中心 | 我要投稿 云计算网_泰州站长网 (http://www.0523zz.com/)- 视觉智能、AI应用、CDN、行业物联网、智能数字人!
当前位置: 首页 > 综合聚焦 > 编程要点 > 语言 > 正文

vuex中刷新数据消失的问题怎样解决?

发布时间:2022-01-01 07:47:45 所属栏目:语言 来源:互联网
导读:这篇文章给大家分享的是vuex中刷新数据消失的问题的解决方法,下文有具体的问题分析、解决思路及方法,文中示例代码介绍的非常详细,感兴趣的朋友接下来一起跟随小编看看吧。 vue构建的单页大型项目中,可能会用到Vuex 。Vuex 的状态存储是响应式的,当 Vue
 这篇文章给大家分享的是vuex中刷新数据消失的问题的解决方法,下文有具体的问题分析、解决思路及方法,文中示例代码介绍的非常详细,感兴趣的朋友接下来一起跟随小编看看吧。
 
    vue构建的单页大型项目中,可能会用到Vuex 。Vuex 的状态存储是响应式的,当 Vue 组件从 store 中读取状态的时候,若 store 中的状态发生变化,那么相应的组件也会相应地得到高效更新。
 
    但是有一个问题就是:vuex的存储的数据只是在页面的中,相当于我们定义的全局变量,刷新之后,里边的数据就会恢复到初始化状态。但是这个情况有时候并不是我们所希望的。
 
    比如,用户已经登录了,我把登录状态放到state中了,一刷新页面,还要重新登录?购物车里的添加的数据,一刷新要重新添加?
 
    解决思路:
 
    监听页面是否刷新,如果页面刷新了,将state对象存入到sessionStorage/localStorage中。
 
    页面打开之后,判断sessionStorage/localStorage中是否存在state对象,如果存在,则说明页面是被刷新过的,将sessionStorage/localStorage中存的数据取出来给vuex中的state赋值。
 
    如果不存在,说明是第一次打开,则取vuex中定义的state初始值。
 
    sessionStorage和localStorage介绍
 
    H5提供了我们常用的localStorage和sessionStorage。
 
    两者的区别:localStorage生命周期是永久,这意味着除非用户显示在浏览器提供的UI上清除localStorage信息,否则这些信息将永远存在。
 
    存放数据大小为一般为5MB,而且它仅在客户端(即浏览器)中保存,不参与和服务器的通信。sessionStorage仅在当前会话下有效,关闭页面或浏览器后被清除。
 
    存放数据大小为一般为5MB,而且它仅在客户端(即浏览器)中保存,不参与和服务器的通信。
 
    源生接口可以接受,亦可再次封装来对Object和Array有更好的支持。浏览器的支持除了IE7及以下不支持外,其他标准浏览器都完全支持(ie及FF需在web服务器里运行)
 
 
 
    localStorage和sessionStorage都具有相同的操作方法,例如setItem、getItem、removeItem、clear等。
 
    代码:
 
    项目目录结构:
 
 
 
    在项目的入口页面(App.vue)里添加监听刷新事件:
 
name: 'App',
 mounted () {
 window.addEventListener('unload', this.saveState)
 },
 methods: {
 saveState () {
  sessionStorage.setItem('state', JSON.stringify(this.$store.state))
 }
 }
    store里有可能存储了一些涉密的信息,所以一直在 sessionStorage放着不是太好,页面加载完成后,清空或者删除指定的session。
 
 window.addEventListener("load", () => {
  sessionStorage.clear();
 });
    state.js:
 
var state = sessionStorage.getItem('state') ? JSON.parse(sessionStorage.getItem('state')) : {
 count: 1,
 obj: {},
 arr: [1, 2, 3]
}
export default state
    index.js
 
import Vue from 'vue'
import Vuex from 'vuex'
import state from './states'
import mutations from './mutations'
import getters from './getters'
import actions from './actions'
Vue.use(Vuex)
export default new Vuex.Store({
 state,
 mutations,
 getters,
 actions
})
    mutations.js:
 
import {
 SOME_MUTATION
} from './mutation-types.js'
 
export default {
 [SOME_MUTATION] (state) {
 state.count++
 }
}
    mutation-types.js
 
export const SOME_MUTATION = 'SOME_MUTATION'
 
    补充知识:vuex-along有效防止刷新页面后vuex中的数据重置
 
1.vuex-along安装
 
npm i vuex-along --save
 
    2.在store目录下的index.js文件中引入
 
    2.1
 
import {createVuexAlong} from 'vuex-along'
 
    2.2直接上图
 
 
 
    简单说明其中的含义:
 
name:“”“”
 
    //在这块我存入的是localstorage,代表localstorage的键值
 
local:{list:["userInfo"],isFilter:true}
 
    //list:要过滤的vuex中的数据,isFilter代表将userInfo滤过,其余存进localstorage
 
session:false
 
    //对于sessionstorage不进行任何操作

(编辑:云计算网_泰州站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读