欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue3基礎(chǔ)教程之pinia配置和用法

 更新時間:2025年06月14日 10:22:50   作者:Ares_前端  
Vue3項目常用Pinia管理狀態(tài),通過安裝和配置實現(xiàn)數(shù)據(jù)持久化,這篇文章主要介紹了vue3基礎(chǔ)教程之pinia配置和用法的相關(guān)資料,文中通過代碼介紹的非常詳細,需要的朋友可以參考下

vue3 項目經(jīng)常使用狀態(tài)管理器來存儲 用戶信息、token、路由信息 等數(shù)據(jù),vite 項目中使用比較多的一般是 pinia 存儲庫。

1. 安裝pinia

npm install pinia

2. 配置pinia

創(chuàng)建 store 文件夾,在里面創(chuàng)建 index.js ,在 store 下面創(chuàng)建 modules 文件夾,用來管理不同倉庫。

index.js文件

使用一個 index 文件進行統(tǒng)一的導(dǎo)出,就不需要在使用多個倉庫的時候?qū)懚鄠€ import 了。

import { createPinia } from "pinia";
// 導(dǎo)出modules下面的所有倉庫
import { userStore } from "./modules/user"
...
...

const pinia = createPinia()

// 組合api添加$reset方法,用于重置狀態(tài)
pinia.use(({ store }) => {
  const initialState = JSON.parse(JSON.stringify(store.$state))
  store.$reset = () => {
    store.$patch(initialState)
  }
})

export default pinia

export { userStore }

組合api的寫法是沒有重置功能的,需要單獨寫一個 $reset 的方法重置數(shù)據(jù)。

modules下面的倉庫文件

// 創(chuàng)建用戶信息倉庫
import { defineStore } from 'pinia'
export const userStore = defineStore('user', () => {
  let name = ref('張三')
  let age = ref(18)
  let obj = reactive({
    username: '韓梅梅',
    address: '北京'
  })

  const changeName = (val) => {
    name.value = val
  }

  return {
    name,
    age,
    obj,
    changeName
  }
})

main.js中引入pinia倉庫

...
import pinia from '@/store'
app.use(pinia)
...

app.mount('#app')

vue頁面的使用

<template>
  <div>
    <div>{{ user.name }}</div>
    <el-button type="primary" @click="changeName1">修改姓名</el-button>
    <div>{{ age }}</div>
    <el-button type="primary" @click="changeName2">修改年齡</el-button>
  </div>
</template>

<script setup>
import { userStore } from '@/store'
import { storeToRefs } from 'pinia' 
const user = userStore()

// 修改里面的值有3種寫法
const changeName1 = () => {
  // 第一種 => 直接賦值
  user.name = '李四'
  // 第二種 => 使用$patch
  user.$patch({
    name: '李四'
  })
  // 第三種 => 使用倉庫里面的方法
  user.changeName('李四')
};


// 如果是使用解構(gòu)的方式取值的話需要使用這個方法,否則取出來的值不是響應(yīng)式的
let { age } = storeToRefs(user)
// 修改年齡
const changeName2 = () => {
    age.value++
}

// 使用重置方法
const reset = () => {
  user.$reset();
}
</script>

storeToRefs 這個方法是修改解構(gòu)賦值的方法從倉庫取值,讓取出來的值也是響應(yīng)式的。

3. 持久化的插件使用

存儲在倉庫的數(shù)據(jù)如果刷新頁面會丟失,之前都是手動將每個值存到本地存儲中 localStorage 或者sessionStorage 種。pinia-plugin-persistedstate 插件是讓倉庫中的數(shù)據(jù)自動存儲到本地存儲中。

4. pinia-plugin-persistedstate

npm i pinia-plugin-persistedstate

5. 配置持久化插件

store 下面的 index.js 文件中編寫。

第一種方法

如果所有倉庫中的數(shù)據(jù)都需要存儲的情況下。

import { createPersistedState } from 'pinia-plugin-persistedstate' // 引入方法
pinia.use(createPersistedState({  
    storage: localStorage, 
    auto: true  // 自動存儲所有倉庫數(shù)據(jù)到localStorage
})) 

第二種方法

每個倉庫單獨配置持久化的配置 => 將 auto: true 刪除。

modules 下面的 user.js 文件中編寫。

// 創(chuàng)建用戶信息倉庫
import { defineStore } from 'pinia'
export const userStore = defineStore('user', () => {
  ...
  ...
}, {
  // 在這個地方配置持久化
  persist: {
    ... 持久化配置如下
  }
})

持久化配置方式如下:

1. 第一種配置
persist: true  // 整個倉庫持久化

2. 第二種配置 (pick 和 omit 二選一)
persist: {
    pick: ['obj.username', 'name'],  // 存儲哪些
    omit: ['obj.address']  // 忽略哪些不存儲
}

3. 第三種配置
persist: {
    storage: sessionStorage 存儲的位置
}

4. 第四種配置
persist: {
    key: 'my-userinfo' 存儲的名稱
}

5. 第五種配置 (一個倉庫每個參數(shù)不同的存儲方式)
persist: [
    {
      pick: ['name'],
      storage: localStorage,
      key: 'name'
    },
    {
      pick: ['age'],
      storage: sessionStorage,
      key: 'age'
    }
]

以上就是 piniapinia-plugin-persistedstate 插件的使用方式。

總結(jié)

到此這篇關(guān)于vue3基礎(chǔ)教程之pinia配置和用法的文章就介紹到這了,更多相關(guān)vue3 pinia配置和用法內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 淺談vue加載優(yōu)化策略

    淺談vue加載優(yōu)化策略

    這篇文章主要介紹了淺談vue加載優(yōu)化策略,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-03-03
  • Vue防抖與節(jié)流的使用介紹

    Vue防抖與節(jié)流的使用介紹

    防抖和節(jié)流的作用都是防止函數(shù)多次調(diào)用,下面這篇文章主要給大家介紹了關(guān)于vue函數(shù)防抖與節(jié)流的正確使用方法,需要的朋友可以參考下
    2022-12-12
  • Vue.js生命周期鉤子中this指向的常見陷阱分析

    Vue.js生命周期鉤子中this指向的常見陷阱分析

    這篇文章主要介紹了Vue.js生命周期鉤子中this指向的常見陷阱分析,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2025-05-05
  • vue2+elementui進行hover提示的使用

    vue2+elementui進行hover提示的使用

    本文主要介紹了vue2+elementui進行hover提示的使用,主要分為外部和內(nèi)部,具有一定的參考價值,感興趣的可以了解一下
    2021-11-11
  • Vue.js實現(xiàn)表格動態(tài)增加刪除的方法(附源碼下載)

    Vue.js實現(xiàn)表格動態(tài)增加刪除的方法(附源碼下載)

    Vue.js通過簡潔的API提供高效的數(shù)據(jù)綁定和靈活的組件系統(tǒng)。在前端紛繁復(fù)雜的生態(tài)中,Vue.js有幸受到一定程度的關(guān)注,下面這篇文章主要給介紹了Vue.js實現(xiàn)表格動態(tài)增加刪除的方法實例,文末提供了源碼下載,需要的朋友可以參考借鑒。
    2017-01-01
  • Element Notification通知的實現(xiàn)示例

    Element Notification通知的實現(xiàn)示例

    這篇文章主要介紹了Element Notification通知的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • 淺談Vue.js應(yīng)用的四種AJAX請求數(shù)據(jù)模式

    淺談Vue.js應(yīng)用的四種AJAX請求數(shù)據(jù)模式

    本篇文章主要介紹了淺談Vue.js應(yīng)用的四種AJAX請求數(shù)據(jù)模式,本文將詳細介紹在Vue應(yīng)用程序中實現(xiàn)AJAX的四個方法,有興趣的可以了解一下
    2017-08-08
  • 如何使用ant-design-vue的Table組件

    如何使用ant-design-vue的Table組件

    這篇文章主要介紹了如何使用ant-design-vue的Table組件,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • vue實現(xiàn)導(dǎo)航欄效果(選中狀態(tài)刷新不消失)

    vue實現(xiàn)導(dǎo)航欄效果(選中狀態(tài)刷新不消失)

    這篇文章主要為大家詳細介紹了vue實現(xiàn)導(dǎo)航欄效果,選中狀態(tài)刷新不消失,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-12-12
  • vue.js的computed,filter,get,set的用法及區(qū)別詳解

    vue.js的computed,filter,get,set的用法及區(qū)別詳解

    下面小編就為大家分享一篇vue.js的computed,filter,get,set的用法及區(qū)別詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-03-03

最新評論