【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)
      },
    },
  },
})
相关推荐
一个不爱写代码的瘦子1 天前
迭代器和生成器
前端·javascript
拳打南山敬老院1 天前
漫谈 MCP 构建之概念篇
前端·后端·aigc
前端老鹰1 天前
HTML <output> 标签:原生表单结果展示容器,自动关联输入值
前端·html
OpenTiny社区1 天前
OpenTiny NEXT 内核新生:生成式UI × MCP,重塑前端交互新范式!
前端·开源·agent
耶耶耶1111 天前
web服务代理用它,还不够吗?
前端
Liamhuo1 天前
2.1.7 network-浏览器-前端浏览器数据存储
前端·浏览器
洋葱头_1 天前
vue3项目不支持低版本的android,如何做兼容
前端·vue.js
前端小书生1 天前
React 组件渲染
前端·react.js
sjd_积跬步至千里1 天前
CSS实现文字横向无限滚动效果
前端
维他AD钙1 天前
前端基础避坑:3 个实用知识点的简单用法
前端