pinia实现数据持久化插件pinia-plugin-persist-uni

在学习uniapp过程中,看到了pinia-plugin-persist-uni插件,以前面试过程中也有面试过说vuex数据刷新之前的数据就丢失了,之前回答的是把数据存储到数据库或者本地存储。pinia-plugin-persist-uni本质上数据也是本地存储。

1、安装

npm install pinia-plugin-persist-uni

2、使用

main.ts

import piniaPersist from 'pinia-plugin-persist-uni'

const app = createApp(App)

const pinia = createPinia()

pinia.use(piniaPersist)

app.use(pinia)

store文件

写法一:

import { defineStore } from 'pinia'

export const useCounterStore = defineStore('counter',()=>{

const counter = ref(0)

const doubleCount = computed(()=>counter.value*2)

const increment = ()=>{

counter.value++

}

return {

counter,

doubleCount,

increment,

}

},{

persist: {

enabled: true,

strategies: [

{

key: 'aaa', // 存储的键名

storage: localStorage, // 存储方式,可以是 localStorage 或 sessionStorage

},

],

},

})

写法二

export const useCounterStore = defineStore('counter', {

state: () => ({

counter: 0,

}),

getters: {

doubleCount: (state) => state.counter * 2,

},

actions: {

increment() {

this.counter++

},

},

persist: {

enabled: true,

strategies: [

{

key: 'counter', // 存储的键名

storage: localStorage, // 存储方式,可以是 localStorage 或 sessionStorage

},

],

}

})

效果:

相关推荐
深红21 小时前
玩转小程序AR-基础篇
前端·微信小程序·webvr
风止何安啊21 小时前
从 “牵线木偶” 到 “独立个体”:JS 拷贝的爱恨情仇(浅拷贝 VS 深拷贝)
前端·javascript·面试
漫天黄叶远飞21 小时前
地址与地基:在 JavaScript 的堆栈迷宫里,重新理解“复制”的哲学
前端·javascript·面试
杨啸_新房客21 小时前
如何优雅的设置公司的NPM源
前端·npm
ohyeah21 小时前
深入理解 JavaScript 中的继承与 instanceof 原理
前端·javascript
linhuai21 小时前
flutter如何实现有登陆权限管理
前端
crary,记忆21 小时前
React 之 useEffect
前端·javascript·学习·react.js
BD_Marathon21 小时前
【JavaWeb】HTML常见标签——标题段落和换行
前端·html
小飞侠在吗21 小时前
vue OptionsAPI与CompositionAPI
前端·javascript·vue.js
天涯路s1 天前
qt怎么将模块注册成插件
java·服务器·前端·qt