vuex|vuex 第三方包实现数据持久化的方法
目的:
让在vuex中管理的状态数据同时存储在本地。可免去自己存储的环节。
- 在开发的过程中,像用户信息(名字,头像,token)需要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发生变化
推荐阅读
- android第三方框架(五)ButterKnife
- thinkphp|thinkphp 3.2 如何调用第三方类库
- Android7.0|Android7.0 第三方应用无法访问私有库
- VueX--VUE核心插件
- vuex|vuex 基础结构
- VueX(Vuex|VueX(Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式)
- iOS常用第三方库
- 解决vuex刷新页面数据丢失
- 【微信开放平台】微信第三方扫码登录(亲测可用)
- 还在用vuex?来了解一下pinia