Vuex持久化插件-解决刷新数据消失的问题

vuex能够进行全局的状态管理,但刷新后刷新后数据会消失,这是咱们不肯意看到的。怎么解决呢,咱们能够结合本地存储作到数据持久化,也能够经过插件-vuex-persistedstatejavascript

欢迎来点点个人我的博客 vue

1.手动利用HTML5的本地存储

方法java

  • vuex的state在localStorage或sessionStorage或其它存储方式中取值
  • 在mutations,定义的方法里对vuex的状态操做的同时对存储也作对应的操做。

这样state就会和存储一块儿存在而且与vuex同步git

问题github

  • 最直观的就是,手动写比较麻烦。

2.利用vuex-persistedstate插件

插件的原理其实也是结合了存储方式,只是统一的配置就不须要手动每次都写存储方法vuex

使用方法npm

  • 安装
npm install vuex-persistedstate  --save
复制代码
  • 引入及配置数组

    在store下的index.js中cookie

import createPersistedState from "vuex-persistedstate"
const store = new Vuex.Store({
  // ...
  plugins: [createPersistedState()]
})
复制代码

默认存储到localStoragesession

想要存储到sessionStorage,配置以下

import createPersistedState from "vuex-persistedstate"
const store = new Vuex.Store({
  // ...
  plugins: [createPersistedState({
      storage: window.sessionStorage
  })]
})
复制代码

想使用cookie同理 默认持久化全部state

指定须要持久化的state,配置以下

import createPersistedState from "vuex-persistedstate"
const store = new Vuex.Store({
  // ...
  plugins: [createPersistedState({
      storage: window.sessionStorage,
      reducer(val) {
      	return {
      	// 只储存state中的assessmentData
    	  assessmentData: val.assessmentData
    	}
	 }
  })]
复制代码

vuex引用多个插件的写法

譬如:vuex提示的插件和持久化的插件一块儿使用,配置以下

import createPersistedState from "vuex-persistedstate"
import createLogger from 'vuex/dist/logger'
// 判断环境 vuex提示生产环境中不使用
const debug = process.env.NODE_ENV !== 'production'
const createPersisted = createPersistedState({
  storage: window.sessionStorage
})
export default new Vuex.Store({
 // ...
  plugins: debug ? [createLogger(), createPersisted] : [createPersisted]
})
复制代码

plugins要是一个一维数组否则会解析错误

补充: 同时使用多个储存方式(譬如一些使用sessionStorage一些使用localStorage)

看github上的文档发现没有直接能够这样使用的方式,因此我采用建立多个实例的方式,以下

const createPersisted = createPersistedState({
  storage: window.sessionStorage,
  // 移除sessionState储存的device
  reducer: (vuexState) => {
    let sessionState = Object.assign({}, vuexState)

    for (let key in sessionState) {
      if (key === 'device') {
        delete sessionState[key]
      }
    }
    return sessionState
  }
})
const createStorage = createPersistedState({
  key: 'vuexStorage',
  storage: window.localStorage,
  reducer: (vuexState) => {
  // localStorage只储存device信息
    return vuexState.device
  }
})

export default new Vuex.Store({
  state,
  getters,
  mutations,
  actions,
  modules: {
    device
  },
  strict: debug,
  plugins: debug ? [createLogger(), createStorage, createPersisted] : [createStorage, createPersisted]
})
复制代码
  • reducer: function 返回须要储存的state对象

删除存储内容

有个思路是:写一个mutaition方法,作的事是将全部state制为初始值

点击跳转插件GITHUB地址

相关文章
相关标签/搜索