【uniapp】状态存储Pinia的使用,以及它的数据持久化

1、下载安装pinia,引入pinia

javascript 复制代码
//stores->index.ts
import { createPinia } from 'pinia'
import persist from 'pinia-plugin-persistedstate' //持久化插件

// 创建 pinia 实例
const pinia = createPinia()
// 使用持久化存储插件
pinia.use(persist)

// 默认导出,给 main.ts 使用
export default pinia

// 模块统一导出
export * from './modules/member'
// export * from './modules/xxxxx' //如果有多个模块,依次导出即可
// export * from './modules/xxxxx' //如果有多个模块,依次导出即可

并且在main.ts中引入:

javascript 复制代码
import { createSSRApp } from 'vue'
import pinia from './stores'

import App from './App.vue'
export function createApp() {
  const app = createSSRApp(App)

  app.use(pinia)
  return {
    app,
  }
}

2、定义pinia,并持久化

javascript 复制代码
//stores->modules->member.ts
import { defineStore } from 'pinia'

// 定义 Store
export const useMemberStore = defineStore('member', {
  state: () => ({
    profile: null,
  }),
  actions: {
    setProfile(obj: any) {
      this.profile = obj
    },
    clearProfile() {
      this.profile = null
    },
  },
  //pinia数据持久化
  persist: {
    storage: {
      getItem(key) {
        return uni.getStorageSync(key)
      },
      setItem(key, value) {
        return uni.setStorageSync(key, value)
      },
    },
  },
})
相关推荐
前端OnTheRun6 分钟前
如何禁用项目中的ESLint配置?
javascript·vue.js·eslint
Felixwb66612 分钟前
Python 爬虫框架设计:类封装与工程化实践
前端
前端无涯12 分钟前
APP 内嵌 H5 复制功能实现:从现代 API 到兼容兜底方案
javascript
广州华水科技12 分钟前
潜力榜单2025年单北斗GNSS位移监测高口碑产品推荐
前端
xinyu_Jina14 分钟前
OpenNana 提示词图库:多模态数据检索、分面搜索与前端性能工程
前端
暴富的Tdy19 分钟前
【脚手架创建 Vue3 公共组件库】
前端·npm·npm发布
技术宅小温22 分钟前
< 前端大小事: 2025年近期CSDN前端技术热点分析 >
前端
知了清语26 分钟前
pkg.pr.new 快速验证第三方包-最新修复
前端
iFlow_AI26 分钟前
知识驱动开发:用iFlow工作流构建本地知识库
前端·ai·rag·mcp·iflow·iflow cli·iflowcli
wordbaby27 分钟前
TanStack Router 文件命名约定
前端