vuex 第三方包实现数据持久化的方法
时间:2022-03-15 08:07:27|栏目:vue|点击: 次
目的:
让在vuex中管理的状态数据同时存储在本地。可免去自己存储的环节。
- 在开发的过程中,像用户信息(名字,头像,token)需要vuex中存储且需要本地存储。
- 如果有别的模块也需要持久化,也存储在本地
1)首先:我们需要安装一个vuex的插件vuex-persistedstate来支持vuex的状态持久化。
npm i vuex-persistedstate
2)然后:在src/store 文件夹下新建 modules 文件,在 modules 下新建 user.js 和 cart.js
src/store/modules/user.js
// 用户模块 export default { namespaced: true, state () { return { // 用户信息 profile: { id: '', avatar: '', nickname: '', account: '', mobile: '', token: '' } } }, mutations: { // 修改用户信息,payload就是用户信息对象 setUser (state, payload) { state.profile = payload } } }
3)继续:在 src/store/index.js 中导入 user 模块。
import { createStore } from 'vuex' import user from './modules/user' export default createStore({ modules: { user } })
4)最后:使用 vuex-persistedstate 插件来进行持久化
import { createStore } from 'vuex' +import createPersistedstate from 'vuex-persistedstate' import user from './modules/user' export default createStore({ modules: { user }, + plugins: [ + createPersistedstate({ + key: 'erabbit-client-pc-store', + paths: ['user'] + }) + ] })
注意:
- ===> 默认是存储在localStorage中
- ===> key是存储数据的键名
- ===> paths是存储state中的那些数据,如果是模块下具体的数据需要加上模块名称,如user.token
- ===> 修改state后触发才可以看到本地存储数据的的变化。
总结:
- 基于第三方包实现vuex中的数据的持久化
- 触发持久化的条件是state发生变化
栏 目:vue
下一篇:Vue组件如何自动按需引入详析
本文标题:vuex 第三方包实现数据持久化的方法
本文地址:http://www.codeinn.net/misctech/196244.html