(03/06/21) Vuex-持久化

一、背景

在开发的过程中,像用户信息(名字,头像,token)需要vuex中存储且需要本地存储,再例如,购物车如果需要未登录状态下也支持,如果管理在vuex中页需要存储在本地

二、实现步骤

  1. 安装vuex-persistedstate 插件
  2. vuex中准备user模块cart模块
  3. 将插件配置到vuex的plugins选项中,配置user模块和cart模块进行状态持久化
  4. 修改state数据就会触发自动同步机制,修改一下数据检测是否同步成功

三、代码落地

1. 安装插件vuex-persistedstate

安装一个vuex的插件vuex-persistedstate来支持vuex的状态持久化

npm i vuex-persistedstate

2. 在src/store 文件夹下新建 modules 文件,在 modules 下新建 user.jscart.js

src/store/modules/user.js

// 用户状态
export default {
  namespaced: true,
  state: () => ({
    id: '',
    nickname: '',
    avatar: '',
    token: '',
    mobile: ''
  })
}
export default user

src/store/modules/cart.js

// 购物车状态
export default {
  namespaced: true,
  state: () => ({
      list:[]
  })
}

3. 在 src/store/index.js 中导入 user 和 cart 模块

import { createStore } from 'vuex'
import user from './modules/user'
import cart from './modules/cart'

export default createStore({
  modules: {
    user,
    cart
  }
})

4. 使用vuex-persistedstate插件来进行持久化

import { createStore } from 'vuex'
import createPersistedstate from 'vuex-persistedstate'
import user from './modules/user'
import cart from './modules/cart'

export default createStore({
  modules: {
    user,
    cart
  },
  plugins: [
    createPersistedstate({
      key: 'erabbit-client-pc-store',
      paths: ['user', 'cart']
    })
  ]
})

5. 测试效果

user模块定义了一个mutation在min.js去调用一下, 观察浏览器application的locaStorage下是否已经存在数据

src/store/modules/user.js

// 测试代码
mutations: {
    setUser (state) {
      state.id = 10001
    }
}

src/main.js

store.commit('user/setUser')

四、 插件说明

  1. 默认是存储在localStorage中,可以对存储的方法进行自定义

  2. key是存储数据的键名

  3. paths是存储state中的那些数据,如果是模块下具体的数据需要加上模块名称,如user.token

  4. 修改state中的数据即可触发同步机制,可以看到本地存储数据的的变化

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值