在uniapp中使用vuex如何将modules模块持久化存储?

问题

H5应用中存在Vuex中的数据在刷新页面后丢失了。

原因

Vuex的 store 中的数据是保存在运行内存中的,当页面刷新时,页面会重新加载 Vue 实例,Vuex数据会重新初始化,导致页面刷新Vuex中的数据丢失的问题。

解决方法

使用 vuex-persistedstate 插件

解决步骤

1.安装插件

npm install --save vuex-persistedstate

2.在store/index.js中配置

import createPersistedState from 'vuex-persistedstate' // 引入数据持久化插件
import Vue from "vue"
import Vuex from "vuex"
import system from "@/store/modules/system.js"
import cars from "@/store/modules/cars.js"
import getters from "./getters"
Vue.use(Vuex)

const store = new Vuex.Store({
	getters,
	modules:{
		system,
		cars
	},	
	plugins: [
		createPersistedState({
			paths: ['cars'],
			storage: { // 存储方式定义  
				getItem: (key) => uni.getStorageSync(key), // 获取  
				setItem: (key, value) => uni.setStorageSync(key, value), // 存储  
				removeItem: (key) => uni.removeStorageSync(key) // 删除  
			}
		})
	]
})

export default store

插件的api说明:

  • key: 存储持久状态的key(默认vuex)
  • reduce: 存储持久状态的key(默认vuex)
  • paths :部分持续状态的任何路径的数组。如果没有路径给出,完整的状态是持久的。(默认:[])
  • reducer :一个函数,将被调用来基于给定的路径持久化的状态。默认包含这些值。
  • subscriber :一个被调用来设置突变订阅的函数。默认为store => handler => store.subscribe(handler)
  • storage :而不是(或与)getState和setState。默认为localStorage。
  • getState :将被调用以重新水化先前持久状态的函数。默认使用storage。
  • setState :将被调用来保持给定状态的函数。默认使用storage。
  • filter :将被调用来过滤将setState最终触发存储的任何突变的函数。默认为() => true
  • 6
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
UniApp ,你可以使用 `vuex-persistedstate` 库来实现 Vuex持久化。`vuex-persistedstate` 是一个用于在 Vuex 持久化状态的插件,它可以将 Vuex 状态保存到本地存储,以确保在刷新页面或重新打开应用时能够保留状态。 以下是在 UniApp 使用 `vuex-persistedstate` 实现 Vuex 持久化的步骤: 1. 安装 `vuex-persistedstate` 库: ``` npm install vuex-persistedstate ``` 2. 在 Vuex 的 store 文件引入 `vuex-persistedstate`: ```javascript import createPersistedState from 'vuex-persistedstate'; ``` 3. 在创建 Vuex 的 store 实例时,将 `createPersistedState` 作为插件添加到选项: ```javascript const store = new Vuex.Store({ // ...其他配置 plugins: [createPersistedState()] }); ``` 4. 配置需要持久化模块: ```javascript const store = new Vuex.Store({ // ...其他配置 plugins: [createPersistedState({ key: 'yourKey', // 可选,用于自定义存储的键名,默认为 'vuex' paths: ['yourModule'], // 可选,指定需要持久化模块,默认为全部模块 storage: uni.getStorageSync // 可选,自定义存储引擎,默认使用本地缓存 uni.getStorageSync })], modules: { yourModule: { // your module configuration } } }); ``` 在上述示例,你可以通过 `key` 选项来自定义存储的键名,通过 `paths` 选项来指定需要进行持久化模块,通过 `storage` 选项来指定自定义的存储引擎。 这样,当你使用 Vuex 存储状态时,`vuex-persistedstate` 会将状态自动保存到本地存储,并在应用重新加载时还原状态。 请注意,在小程序使用本地缓存进行持久化时,需要使用 `uni.getStorageSync` 作为存储引擎。如果需要在其他平台或环境实现持久化,可以根据不同的需求选择适当的存储引擎。 希望这可以帮助到你实现 UniApp Vuex 持久化

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

咸虾米_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值