1.安装
npm i pinia-plugin-persistedstate
2.配置(main.js)
import { createApp } from 'vue'
import { createPinia } from 'pinia'
import piniaPluginPersistedstate from 'pinia-plugin-persistedstate'
import App from './App.vue'
import router from './router'
import './assets/main.css'
const app = createApp(App)
// pinia持久化插件
const pinia = createPinia()
pinia.use(piniaPluginPersistedstate)
// app.use(createPinia()) //注意点这个要改写成 app.use(pinia)
app.use(pinia)
app.use(router)
app.mount('#app')
注意事件createPinia事件太多会导致持久化存储无法储存
看图:createPinia太多时与正常时,
createPinia只能有两次出现:
import { createApp } from ‘vue’ 与 const pinia = createPinia()
3.使用
(一般直接储存到localstorage里)
// vue2
import { defineStore } from 'pinia'
export const useStore = defineStore('main', {
state: () => {
return {
someState: '你好 pinia',
}
},
persist: true,
})
// vue3
import { defineStore } from 'pinia'
export const useStore = defineStore(
'main',
() => {
const someState = ref('你好 pinia')
return { someState }
},
{
persist: true,
},
)