Vue狀態(tài)管理之使用Pinia代替Vuex
1、Pinia是什么
Pinia
是一個(gè)vue
的狀態(tài)管理方案,是vuex
團(tuán)隊(duì)成員開發(fā),實(shí)現(xiàn)了很多vuex5
的提案,更加地輕量化且有devtools
的支持
vuex4
一直被人詬病對(duì)于typescript
的支持不良好,vuex5
也遲遲未來
所以有了pinia的出現(xiàn)
相較于vuex:
pinia
無需創(chuàng)建復(fù)雜的包裝器來支持typescript
,對(duì)于typescript
類型判斷是天然支持的,享受ide帶來的自動(dòng)補(bǔ)全,減少開發(fā)的心智負(fù)擔(dān),減少vue開發(fā)過程中的面向字符串編程- 減去了mutations的概念,只保留
state
,getters
和anctions
三個(gè)概念,減少代碼冗余 - 無需手動(dòng)添加store,創(chuàng)建的store會(huì)在使用時(shí)自動(dòng)添加
- 沒有模塊
module
的概念,不用面對(duì)一個(gè)store下嵌套著許多模塊,使用單文件store(有點(diǎn)類似redux/toolkit的一個(gè)reducer),可以直接導(dǎo)入其他store使用
Pinia文檔有這么一段話:
Pinia 試圖盡可能接近 Vuex 的理念。 它旨在測(cè)試 Vuex 下一次迭代的提案,并且取得了成功,因?yàn)槲覀兡壳坝幸粋€(gè)針對(duì) Vuex 5 的開放 RFC,其 API 與 Pinia 使用的 API 非常相似。 請(qǐng)注意,我(Eduardo),Pania 的作者,是 Vue.js 核心團(tuán)隊(duì)的一員,并積極參與了 Router 和 Vuex 等 API 的設(shè)計(jì)。 我個(gè)人對(duì)這個(gè)項(xiàng)目的意圖是重新設(shè)計(jì)使用全局 Store 的體驗(yàn),同時(shí)保持 Vue 平易近人的哲學(xué)。 我讓 Pania 的 API 與 Vuex 一樣接近,因?yàn)樗粩嘞蚯鞍l(fā)展,以便人們可以輕松地遷移到 Vuex 或什至在未來融合兩個(gè)項(xiàng)目(在 Vuex 下)。
所以現(xiàn)在學(xué)習(xí)Pinia
,相當(dāng)于提前學(xué)習(xí)Vuex5就是說
2、Pinia簡(jiǎn)單上手
首先我們初始化一個(gè)vite+vue+ts工程
pnpm create vite pinia-demo -- --template vue-ts
安裝pinia
pnpm i pinia
打開項(xiàng)目,編輯src目錄下的mian.ts文件,引入Pinia
// main.ts import { createApp } from 'vue' import App from './App.vue' import { createPinia } from 'pinia' createApp(App).use(createPinia()).mount('#app')
在src
目錄下創(chuàng)建一個(gè)store
文件夾用來存放狀態(tài)管理,然后新建一個(gè)counter.ts
,我們來做一個(gè)簡(jiǎn)單的計(jì)數(shù)器狀態(tài)應(yīng)用
import { defineStore } from 'pinia' export const useCounterStore = defineStore('counter', { state: () => { return { count: 0, } }, getters: { doubleCount: (state) => state.count * 2, }, actions: { increment() { this.count++ }, }, })
Pinia
通過defineStore
函數(shù)來創(chuàng)建一個(gè)store
,它接收一個(gè)id
用來標(biāo)識(shí)store
,以及store
選項(xiàng)
我們也可以使用一個(gè)回調(diào)函數(shù)來返回options
,回調(diào)函數(shù)體內(nèi)的寫法類似vue
的setup()
寫法,比如上面的定義可以寫成
export const useCounterStore = defineStore('counter', () => { const count = ref(0) function doubleCount() { return count.value * 2 } function increment() { count.value++ } return { count, increment } })
接著我們?cè)?code>App.vue中使用store
<script setup lang="ts"> import { useCounterStore } from './store/counter' const useCounter = useCounterStore() </script> <template> <h2>{{ useCounter }}</h2> <h2>{{ useCounter.count }}</h2> <h2>{{ useCounter.doubleCount() }}</h2> <button @click="useCounter.increment">increment</button> </template> <style> #app { font-family: Avenir, Helvetica, Arial, sans-serif; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; text-align: center; color: #2c3e50; margin-top: 60px; } </style>
在使用Pinia
的過程中可以發(fā)現(xiàn)自動(dòng)補(bǔ)全是相當(dāng)優(yōu)秀
瀏覽器運(yùn)行如下:
打開開發(fā)者工具查看vue devtool
vue devtool
支持對(duì)Pinia
狀態(tài)的增刪改查!
Pinia有多種對(duì)狀態(tài)的修改方式:
- 使用
actions
,如上面所示 - 直接在狀態(tài)上修改
const countPlus_1 = useCounter.count++
使用store
的$patch
函數(shù),支持選項(xiàng)和回調(diào)函數(shù)兩種寫法,回調(diào)函數(shù)適用于狀態(tài)為數(shù)組或其他之類的需要調(diào)用狀態(tài)方法進(jìn)行修改
const countPlus_2 = useCounter.$patch({ count: useCounter.count + 1 }) const countPlus_3 = useCounter.$patch((state) => state.count++)
對(duì)狀態(tài)的結(jié)構(gòu)需要使用StoreToRefs
函數(shù)
const { count } = storeToRefs(useCounter)
3、使用體驗(yàn)
Pinia
的學(xué)習(xí)和使用是相當(dāng)友好的,看一遍官方文檔就能上手,在上手過程中可以明顯地感受到相對(duì)于vuex
更加快捷,編碼體驗(yàn)優(yōu)秀。
狀態(tài)管理對(duì)于小項(xiàng)目來說更注重于方便和快捷(甚至可以不想需要),所以像vuex是稍微有些復(fù)雜了,像vue3出beta
的時(shí)候就有人說可以使用組合式api
比如provide
跟inject
配合來替代vuex
,所以Pinia
這個(gè)輕量級(jí)狀態(tài)管理方案的出現(xiàn)是相當(dāng)及時(shí)的。
到此這篇關(guān)于Vue狀態(tài)管理之使用Pinia代替Vuex的文章就介紹到這了,更多相關(guān)使用Pinia代替Vuex內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
解決echarts圖表使用v-show控制圖表顯示不全的問題
這篇文章主要介紹了解決echarts圖表使用v-show控制圖表顯示不全的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-07-07解決Vue 項(xiàng)目打包后favicon無法正常顯示的問題
今天小編就為大家分享一篇解決Vue 項(xiàng)目打包后favicon無法正常顯示的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-09-09Nuxt.js SSR與權(quán)限驗(yàn)證的實(shí)現(xiàn)
這篇文章主要介紹了Nuxt.js SSR與權(quán)限驗(yàn)證的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-11-11Vue高性能列表GridList組件及實(shí)現(xiàn)思路詳解
這篇文章主要為大家介紹了Vue高性能列表GridList組件及實(shí)現(xiàn)思路詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-11-11vue實(shí)現(xiàn)登錄時(shí)滑塊驗(yàn)證
這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)登錄時(shí)滑塊驗(yàn)證,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03Vue.js實(shí)現(xiàn)的計(jì)算器功能完整示例
這篇文章主要介紹了Vue.js實(shí)現(xiàn)的計(jì)算器功能,結(jié)合完整實(shí)例形式分析了vue.js響應(yīng)鼠標(biāo)事件實(shí)現(xiàn)基本的數(shù)值運(yùn)算相關(guān)操作技巧,可實(shí)現(xiàn)四則運(yùn)算及乘方、開方等功能,需要的朋友可以參考下2018-07-07Vue-CLI 3.X 部署項(xiàng)目至生產(chǎn)服務(wù)器的方法
這篇文章主要介紹了Vue-CLI 3.X 部署項(xiàng)目至生產(chǎn)服務(wù)器的方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-03-03