vuejs3 pinia持久化存储

pinia地址:

开始 | Pinia

插件地址:

快速开始 | pinia-plugin-persistedstate

先安装pinia

javascript 复制代码
npm install pinia

再安装插件

安装pinia后,再安装这个插件

javascript 复制代码
npm i pinia-plugin-persistedstate

全局中引入持久化插件

在src目录下的main.ts或者main.js里

javascript 复制代码
//main.ts或者main.js里

import { createApp } from 'vue'
import App from './App.vue'
import { createPinia } from 'pinia'

//注意下面没有{}
import piniaPluginPersistedstate from 'pinia-plugin-persistedstate'

const app = createApp(App)
const pinia = createPinia()             //创建pinia
pinia.use(piniaPluginPersistedstate)    //把pinia插件,注册到pinia中
app.use(pinia)
app.mount('#app')

持久化插件配置:

stores目录下的userStore.js (根据实际使用选择)

所有数据持久化配置。

javascript 复制代码
import {ref, computed, reactive} from 'vue'
import {defineStore} from 'pinia'  //只引入pinia就可以了

export const useUserStore = defineStore('user', () => {
        const userInfo = reactive({})
        return {userInfo}
    }, 
    //这里是第三个参数
    {
        persist: true  //加上这一个,所有的数据都可以持久化
    }
)

指定数据持久化配置。

javascript 复制代码
import {ref, computed, reactive} from 'vue'
import {defineStore} from 'pinia'  //只引入pinia就可以了

export const useUserStore = defineStore('user', () => {
        const userInfo = reactive({})
        return {userInfo}
    }, 
    //这里是第三个参数
    {
         persist: {
            paths: ['name', 'info.des'] //指定 name, info.des持久化
         },
    }
)

使用插件:

赋值,持久化的数据

javascript 复制代码
<script setup>
//引入配置好的store
import {useUserStore} from "@/stores/userStore.js"
//实例化store
const userStore = useUserStore()




//...一堆逻辑后面赋值且自动持久化,使用的是'所有数据持久化配置'
 userStore.$patch({
    userInfo:res2.data
})
</script>

调用,持久化的数据

javascript 复制代码
<script setup>
//引入配置好的store
import {useUserStore} from "../stores/userStore.js";
//实例化store
const userStore = useUserStore()
</script>


<template>
<!--template中调用store内的信息-->
  <div>
    {{ userStore.userInfo }}
  </div>
</template>

清空,持久化的数据

javascript 复制代码
<script setup>
//引入配置好的store
import {useUserStore} from "@/stores/userStore.js"
//实例化store
const userStore = useUserStore()


//清空持久化数据userInfo
  userStore.$patch({
    userInfo:{}
  })

//下面这种写法,虽然可以清空,但是无法再次赋值,强制不推荐使用
//userStore.userInfo = {}
</script>
相关推荐
GuMoYu10 分钟前
el-date-picker限制选择范围
前端·javascript·vue.js
a31582380616 分钟前
Android 大图显示策略优化显示(二)
android·java·开发语言·javascript·kotlin·glide·图片加载
计算机毕设VX:Fegn089523 分钟前
计算机毕业设计|基于springboot + vue律师咨询系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
冴羽32 分钟前
JavaScript Date 语法要过时了!以后用这个替代!
前端·javascript·node.js
前端小L1 小时前
专题一:搭建测试驱动环境 (TypeScript + Vitest)
前端·javascript·typescript·源码·vue3
San30.1 小时前
告别全局污染:深入解析现代前端的模块化 CSS 演进之路
前端·css·vue.js·react.js
我想吃烤肉肉1 小时前
wait_until=“domcontentloaded“ 解释
开发语言·前端·javascript·爬虫·python
xkxnq1 小时前
第一阶段:Vue 基础入门(第 12天)
前端·javascript·vue.js
q_19132846951 小时前
基于Springboo和vue开发的企业批量排班系统人脸识别考勤打卡系统
前端·javascript·vue.js·spring boot·mysql·毕业设计·人脸识别
BianHuanShiZhe1 小时前
swift计算文本高度
前端·javascript·html