Pinia 本身不自带持久化能力,状态默认存在内存中,页面刷新就清空;需借助插件如 pinia-plugin-persistedstate(H5)或 pinia-plugin-unistorage(UniApp)实现自动存取本地存储,通过声明式配置 persist 字段控制字段级持久化,并注意 JSON 序列化限制与平台存储差异。
Pinia 本身不自带持久化能力,状态默认存在内存中,页面刷新就清空。要实现跨页面(包括刷新、关闭再打开)的状态持久化,核心是把关键 state 自动存到本地存储,并在应用启动时自动读取还原。
不同平台的本地存储 API 不一样,不能直接套用 localStorage:
pinia-plugin-persistedstate,它默认对接 localStorage,开箱即用pinia-plugin-unistorage 或 pinia-plugin-persist-uni,它们能自动识别当前平台(比如小程序调用 uni.setStorageSync,H5 调用 localStorage),统一处理存储逻辑不是所有状态都需要存——比如临时搜索关键词、动画开关就不必。只对登录信息、用户偏好、购物车等关键数据开启持久化。配置方式很直观:
export const useUserStore = defineStore('user', { state: () => ({ token: '', userInfo: null, theme: 'light' }), persist: { enabled: true, // 可指定只存哪些字段(避免存大对象或敏感信息) paths: ['token', 'userInfo', 'theme'] }})
插件会在 state 变更时自动写入,应用初始化时自动从本地读取并合并进 store,开发者不用手动调用 setItem / getItem。
本地存储只能存字符串,插件内部会自动 JSON 序列化,但你要避开不能被 JSON 安全转换的内容:
serializer 选项)别只靠“刷新看还在不在”来判断,建议主动检查:
onMounted 或 setup 中打印 store.$state,确认初始化后已加载本地数据