Nuxt.js 3.x 狀態管理 State Management (3)-Pinia Plugin Persistedstate

本篇文章同步發表於 2023 iThome 鐵人賽:Nuxt.js 3.x 筆記-打造 SSR 專案

前一篇 說明了在 Nuxt3 搭配 Pinia 狀態管理工具全域共享狀態,本篇將介紹 pinia-plugin-persistedstate 套件,用來將 Store 狀態儲存於瀏覽器中,避免狀態被還原

Pinia Plugin Persistedstate

pinia-plugin-persistedstate 用來將 Store 狀態保存於使用者的瀏覽器中,以下兩個情境推薦使用:

  • 使用者下次再瀏覽畫面時,需保存先前操作的狀態
  • 避免頁面重新整理時,狀態被還原

套件安裝

搭配 Nuxt 整合模組 @pinia-plugin-persistedstate/nuxt 進行安裝:

npm install -D @pinia-plugin-persistedstate/nuxt

pinia-plugin-persistedstate 必須搭配 Pinia 使用


nuxt.config 配置

// nuxt.config.js
export default defineNuxtConfig({
modules: [
'@pinia/nuxt',
'@pinia-plugin-persistedstate/nuxt'
]
})

Store 開啟狀態保存

Option Store

將 persist 參數設定為 true

// store/index.js
export const useMainStore = defineStore('main', {
state: () => ({
counter: 0
}),
getters: {
doubleCounter() {
return this.counter * 2;
}
},
actions: {
increment() {
this.counter++;
}
},
persist: true
});

Setup Store

defineStore 傳入參數 { persist: true }

// store/index.js
export const useMainStore = defineStore(
'main',
() => {
const counter = ref(0);
const doubleCounter = computed(() => counter.value * 2);
const increment = () => {
counter.value++;
};

return {
counter,
doubleCounter,
increment
};
},
{
persist: true
}
);

選項配置

預設配置:

  • 儲存於 cookie
  • 預設 key 為 store.$id
  • 使用 JSON.stringify()JSON.parse() 進行序列化 / 反序列化
  • 預設整個 state 都會被保存

Key

型別:string
預設值:store.$id

以下為例,預設 key 為 main,調整為 my-custom-key

// store/index.js
export const useMainStore = defineStore('main',
() => {
// ...
},
{
persist: {
key: 'my-custom-key'
}
}
);

在儲存庫可以看到調整後的 key 值

storage

預設值:cookie
選項:localStoragesessionStoragecookie

使用自動引入的 persistedState 變數進行配置

// store/index.js
export const useMainStore = defineStore('main',
() => {
// ...
},
{
persist: {
storage: persistedState.localStorage
}
}
);

因 storage 只存在瀏覽器端,如果未搭配 persistedState 定義,在 ssr 會出現錯誤,也可以透過判斷式定義:

{
persist: {
storage: process.client ? localStorage : null
}
}

cookiesWithOptions()

用來設定 cookie,選項同 Nuxt Composable useCookie,storage 需為 cookie 才能使用

// store/index.js
export const useMainStore = defineStore('main',
() => {
// ...
},
{
persist: {
storage: persistedState.cookiesWithOptions({
sameSite: 'strict'
})
}
}
);

paths

型別:string[]
預設值:undefined

預設整個 state 都會被保存在 storage。如果想指定參數,使用 paths 進行調整

// store/index.js
export const useMainStore = defineStore('main',
() => {
const counter = ref(0);
const user = ref({
name: 'Daniel',
age: 18
});
},
{
persist: {
paths: [
'user.name'
]
}
}
);

serializer

預設值:JSON.stringifyJSON.parse

指定序列化方法(必須包含 serializedeserialize),以下範例調整為壓縮檔

// store/index.js
import { parse, stringify } from 'zipson';

export const useMainStore = defineStore('main',
() => {
// ...
},
{
persist: {
serializer: {
serialize: stringify,
deserialize: parse
}
}
}
);

debug

型別:boolean
預設值:false

設定為 true,當發生任何錯誤,都會使用 conosle.error 印出


全域選項配置

nuxt.config 使用 piniaPersistedstate 全域調整選項

// nuxt.config.js
export default defineNuxtConfig({
modules: [
'@pinia/nuxt',
'@pinia-plugin-persistedstate/nuxt'
],
piniaPersistedstate: {
storage: 'cookie',
cookieOptions: {
sameSite: 'strict'
}
}
})

參考資源:

https://prazdevs.github.io/pinia-plugin-persistedstate/

Nuxt.js 3.x 狀態管理 State Management (2)-Pinia Nuxt.js 3.x 套件應用-Swiper 製作輪播動畫

評論

廣告
Nuxt3 入門-打造 SSR 專案 新書上市
Nuxt3 入門:打造 SSR 專案
Your browser is out-of-date!

Update your browser to view this website correctly. Update my browser now

×