Pinia只能存储简单数据类型

最近用vue做了一个管理后台,登录后使用Pinia存储一个User对象,包括name,token,avator。

在接口中统一拦截,header中添加token。获取Pinia里的对象对应的token值时发现是undefined,于是会出现登录后可以正常访问接口,刷新后就没有带上token,接口返回错误。于是又尝试创建一个新的defineStore,直接保存token,发现可以拿到。原来Pinia只能存储简单数据类型。

Pinia数据持久化可以通过使用pinia-plugin-persistedstate插件来实现。‌

Pinia是一个Vue的状态管理库,它允许开发者跨组件或页面共享状态。为了实现数据的持久化,即让数据在页面刷新或重新加载后依然保持,可以使用pinia-plugin-persistedstate插件。这个插件可以将Pinia管理的状态保存到localStorage或sessionStorage中,从而实现在不同会话或浏览器关闭后数据依然可用。

使用pinia-plugin-persistedstate插件进行数据持久化的基本步骤如下:

‌安装插件‌:首先,需要通过npm安装pinia-plugin-persistedstate插件。

‌导入并使用‌:在项目的入口文件(如main.ts或main.js)中导入createPinia和piniaPluginPersistedstate,并创建Pinia实例。

‌挂载插件‌:将创建的Pinia实例挂载到Vue应用上,并使用piniaPluginPersistedstate插件。

‌在Store中使用‌:在定义Store时,将需要持久化的状态设置为可持久化(通过设置persist属性为true)。

通过这些步骤,Pinia管理的状态就会被自动同步到localStorage或sessionStorage中,从而实现数据的持久化存储。这种方式适用于保存简单的数据类型,如数字、字符串等,因为它直接操作的是浏览器的存储API。对于更复杂的数据类型,可能需要额外的序列化和反序列化处理,以确保数据能够正确地存储和恢复‌ 。

相关推荐
暂时先用这个名字2 个月前
vue3中mitt和pinia的区别和主要用途,是否有可重合的部分?
开发语言·javascript·vue.js·pinia·组件·通信·mitt
白雾茫茫丶2 个月前
前端的全栈之路:基于 Vue3 + Nest.js 全栈开发的后台应用
postgresql·vue3·vite·pinia·nest.js·prisma
濮水大叔2 个月前
在Vue3中如何实现四种全局状态数据的统一管理?
typescript·vue3·pinia
威哥爱编程4 个月前
Vue状态管理库Pinia详解
javascript·vue·pinia
bjzhang754 个月前
Vue快速入门(六)——Vue3 状态管理 - Pinia(一)
前端·javascript·vue.js·pinia
又言又语5 个月前
【Vue3】Pinia修改数据
vue·vue3·pinia
honor_zhang5 个月前
uni-app三部曲之一: Pinia使用
微信小程序·uni-app·pinia
特立独行的猫a5 个月前
Pinia:Vue 2 和 Vue 3 中更好用的状态管理框架
前端·javascript·vue.js·pinia·vuex
啊猪是的读来过倒6 个月前
Vue 全局状态管理新宠:Pinia实战指南
前端·vue.js·flutter·pinia·全局状态管理