网络编程
位置:首页>> 网络编程>> JavaScript>> vuex 第三方包实现数据持久化的方法

vuex 第三方包实现数据持久化的方法

作者:卖小女孩的小火柴  发布时间:2024-04-30 10:34:56 

标签:vuex,数据持久化

目的:

让在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发生变化

来源:https://juejin.cn/post/7006634698822680613

0
投稿

猜你喜欢

手机版 网络编程 asp之家 www.aspxhome.com