【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)
      },
    },
  },
})
相关推荐
liangshanbo121516 小时前
写好 React useEffect 的终极指南
前端·javascript·react.js
哆啦A梦158818 小时前
搜索页面布局
前端·vue.js·node.js
_院长大人_19 小时前
el-table-column show-overflow-tooltip 只能显示纯文本,无法渲染 <p> 标签
前端·javascript·vue.js
SevgiliD19 小时前
el-table中控制单列内容多行超出省略及tooltip
javascript·vue.js·elementui
要加油哦~19 小时前
JS | 知识点总结 - 原型链
开发语言·javascript·原型模式
Q_Q51100828519 小时前
python+uniapp基于微信小程序的旅游信息系统
spring boot·python·微信小程序·django·flask·uni-app·node.js
哆啦A梦158820 小时前
axios 的二次封装
前端·vue.js·node.js
阿珊和她的猫20 小时前
深入理解与手写发布订阅模式
开发语言·前端·javascript·vue.js·ecmascript·状态模式
yinuo20 小时前
一行 CSS 就能搞定!用 writing-mode 轻松实现文字竖排
前端
snow@li21 小时前
html5:拖放 / demo / 拖放事件(Drag Events)/ DataTransfer 对象方法
前端·html·拖放