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

vue3中使用pinia(大菠蘿)狀態(tài)管理倉庫的項目實踐

 更新時間:2023年07月26日 10:31:56   作者:jieyucx  
本文主要介紹了vue3中使用pinia(大菠蘿)狀態(tài)管理倉庫,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

在Vue 3中,狀態(tài)管理是非常重要的一部分。而Pinia(大菠蘿)作為一個全新的狀態(tài)管理庫,在Vue 3中提供了更好的狀態(tài)管理方案,可以方便地實現(xiàn)任意組件之間數(shù)據(jù)共享。與VueX不同的是,Pinia并不依賴于Vue 3的響應(yīng)式系統(tǒng),而是通過手動訂閱和派發(fā)事件的方式來實現(xiàn)狀態(tài)管理。這樣可以提高系統(tǒng)性能,減少數(shù)據(jù)冗余,同時使得代碼更容易測試和維護(hù)。本文將介紹如何在Vue 3中使用Pinia狀態(tài)管理倉庫,并提供一些最佳實踐來幫助您更好地使用它。

一、vue3中使用pinia

Pinia是一個Vue 3的狀態(tài)管理庫,提供了一個易于使用的API和可擴(kuò)展性。下面是如何在Vue 3項目中使用Pinia的步驟:

安裝Pinia

在項目中使用npm或yarn安裝Pinia:

npm install pinia

yarn add pinia

創(chuàng)建和注冊一個Pinia store

創(chuàng)建一個store并導(dǎo)出它,例如:

import { defineStore } from 'pinia'
export const useMyStore = defineStore('myStore', {
? state: () => ({
? ? count: 0,
? }),
? actions: {
? ? increment() {
? ? ? this.count++
? ? },
? },
})

在項目中的任何組件中使用該store,只需導(dǎo)入并使用它:

import { useMyStore } from './store'
export default {
? setup() {
? ? const myStore = useMyStore()
? ? return {
? ? ? count: myStore.count,
? ? ? increment: myStore.increment,
? ? }
? },
}

在Vue應(yīng)用程序中安裝Pinia

在Vue的createApp時,將Pinia安裝為插件:

import { createApp } from 'vue'
import { createPinia } from 'pinia'
import App from './App.vue'
const app = createApp(App)
app.use(createPinia())
app.mount('#app')

現(xiàn)在,您可以在Vue應(yīng)用程序中使用Pinia啦!

備注:由于Vue 3的Composition API的特性,您可以使用useXXX函數(shù)(例如 useMyStore())而不是傳統(tǒng)的mapState、mapActions等選項來訪問store中的狀態(tài)和操作。

二、使用pinia實現(xiàn)任意組件之間數(shù)據(jù)共享

要在Vue 3項目中使用Pinia實現(xiàn)任意組件之間的數(shù)據(jù)共享,您可以按照以下步驟操作:

創(chuàng)建一個名為user的Pinia store,例如:

import { defineStore } from 'pinia'
export const useUserStore = defineStore('user', {
? state: () => ({
? ? name: 'John Doe',
? }),
? actions: {
? ? setName(name) {
? ? ? this.name = name
? ? },
? },
})

在Vue應(yīng)用程序中注冊Pinia store,您需要在入口文件中創(chuàng)建Pinia實例并將其注冊到Vue應(yīng)用程序中。例如:

import { createApp } from 'vue'
import { createPinia } from 'pinia'
import App from './App.vue'
import { useUserStore } from './store/user'
const app = createApp(App)
app.use(createPinia())
app.provide('userStore', useUserStore())
app.mount('#app')

在上面的示例中,我們使用provide API將useUserStore()實例注冊為名為’userStore’的全局可注入實例。

在組件中使用Pinia store,您可以在任何Vue組件中使用創(chuàng)建的Pinia store。例如,在組件A和組件B中,您可以使用以下方式導(dǎo)入user store:

import { useUserStore } from '../store/user'
export default {
? setup() {
? ? const userStore = useUserStore()
? ? return {
? ? ? name: userStore.name,
? ? ? setName: userStore.setName,
? ? }
? },
}

在上面的示例中,我們使用useUserStore()函數(shù)從’./store/user.js’中導(dǎo)入我們的Pinia store,并在setup()函數(shù)中使用store的屬性和操作。

在組件A或組件B中更新user store中的狀態(tài),例如:

import { useUserStore } from '../store/user'
export default {
? setup() {
? ? const userStore = useUserStore()
? ? const handleNameChange = (name) => {
? ? ? userStore.setName(name)
? ? }
? ? return {
? ? ? name: userStore.name,
? ? ? handleNameChange,
? ? }
? },
}

在上面的示例中,我們導(dǎo)入’…/store/user.js’中的user store,并在組件A中使用setName()操作更改store中的狀態(tài)。

在組件B中讀取user store中的狀態(tài),例如:

import { useUserStore } from '../store/user'
export default {
? setup() {
? ? const userStore = useUserStore()
? ? return {
? ? ? name: userStore.name,
? ? }
? },
}

在上面的示例中,我們導(dǎo)入’…/store/user.js’中的user store,并在組件B中使用store的name屬性。

現(xiàn)在,您已經(jīng)成功地在Vue 3項目中使用Pinia實現(xiàn)了任意組件之間的數(shù)據(jù)共享!

三、pinia中的getters

在Vue 3項目中,使用Pinia狀態(tài)管理倉庫,可以使用getter來獲取存儲狀態(tài),這是一個非常有用的特性。getter可以用于計算或轉(zhuǎn)換存儲的狀態(tài),并且能夠更新UI或在其他地方使用。

以下是一個使用getter的示例:

import { defineStore } from 'pinia'
export const useUserStore = defineStore('user', {
? state: () => ({
? ? firstName: 'John',
? ? lastName: 'Doe',
? }),
? getters: {
? ? fullName() {
? ? ? return `${this.firstName} ${this.lastName}`
? ? },
? },
})

在上面的例子中,我們在user store中定義了一個getter函數(shù)fullName。getter函數(shù)返回由firstName和lastName組合成的完整名稱。

現(xiàn)在,可以在組件中使用getter來獲取完整名稱,并將其顯示在UI中,如下所示:

<template>
? <div>{{ fullName }}</div>
</template>
<script>
import { useUserStore } from '../store/user'
export default {
? setup() {
? ? const userStore = useUserStore()
? ? return {
? ? ? fullName: userStore.fullName,
? ? }
? },
}
</script>

在上述代碼中,我們在組件中使用useUserStore鉤子獲取store實例,然后返回完整名稱getter。最后,在模板中將fullName綁定到UI元素,以便在屏幕上顯示完整名稱。

通過使用getter,您可以輕松地計算和轉(zhuǎn)換狀態(tài),并將其暴露給Vue組件中使用。在實際開發(fā)中,getter的應(yīng)用場景非常廣泛,比如處理復(fù)雜的計算邏輯,根據(jù)狀態(tài)屬性的值決定下一步要執(zhí)行的操作等等。

四、pinia的組合式寫法

在Vue 3項目中,除了可以使用Options API來定義Pinia狀態(tài)管理倉庫之外,還可以使用Composition API。下面是一個使用Composition API來定義和使用Pinia狀態(tài)管理倉庫的示例:

//定義組合式API倉庫
import { defineStore } from "pinia";
import { ref, computed,watch} from 'vue';
//創(chuàng)建小倉庫
let useTodoStore = defineStore('todo', () => {
? ? let todos = ref([{ id: 1, title: '吃飯' }, { id: 2, title: '睡覺' }, { id: 3, title: '打豆豆' }]);
? ? let arr = ref([1,2,3,4,5]);
? ? const total = computed(() => {
? ? ? ? return arr.value.reduce((prev, next) => {
? ? ? ? ? ? return prev + next;
? ? ? ? }, 0)
? ? })
? ? //務(wù)必要返回一個對象:屬性與方法可以提供給組件使用
? ? return {
? ? ? ? todos,
? ? ? ? arr,
? ? ? ? total,
? ? ? ? updateTodo() {
? ? ? ? ? ? todos.value.push({ id: 4, title: '組合式API方法' });
? ? ? ? }
? ? }
});
export default useTodoStore;

上述代碼中使用ref定義的todos 和 arr 就相當(dāng)于選項式中的state中的數(shù)據(jù);使用computed計算屬性計算的total就相當(dāng)于選項式中的getters中的屬性;updateTodo方法就相當(dāng)于寫在選項式actions中的方法

五、pinia和vuex的對比

需要注意的是,Vue3 中的 Pinia 不僅支持 Vue2 中 Vuex 所有的功能,而且使用起來更加方便,對 TypeScript 的支持也更加友好。而且 Pinia 只依賴于 Vue3 的響應(yīng)式系統(tǒng),所以可以很容易地跨平臺使用。

特性Vuex (Vue2)Pinia (Vue3)
數(shù)據(jù)存儲State 存儲在 Store 中State 存儲在 Store 中
數(shù)據(jù)修改commit/mutationaction
響應(yīng)式使用 Vue 響應(yīng)式系統(tǒng)實現(xiàn)使用 Vue 3 的響應(yīng)式系統(tǒng)實現(xiàn)
數(shù)據(jù)獲取gettersgetters
模塊化模塊按照功能劃分,每個模塊有自己的 state、mutation、action 和 getter模塊按照功能劃分,每個模塊有自己的 state、action 和 getter
TypeScript 支持需要額外安裝 @vue/cli-plugin-typescript 插件,并在 store 中進(jìn)行類型定義內(nèi)置 TypeScript 支持,使用起來更加方便
插件支持插件(例如 logger 插件)支持插件(例如 devtools 插件)
熱重載支持熱重載支持熱重載

六、總結(jié)

綜上所述,Pinia(大菠蘿)是Vue 3中一個非常重要的狀態(tài)管理庫,它能夠幫助我們更好地管理和共享組件中的數(shù)據(jù)。通過本文的介紹,您已經(jīng)學(xué)會了如何在Vue 3中使用Pinia,以及一些最佳實踐來幫助您更好地使用它。當(dāng)然,這只是入門級別的介紹,并且Pinia仍然有很多特性和功能可以探索。如果您想深入學(xué)習(xí)更多關(guān)于Pinia的內(nèi)容,建議您查閱官方文檔。

到此這篇關(guān)于vue3中使用pinia(大菠蘿)狀態(tài)管理倉庫的文章就介紹到這了,更多相關(guān)vue3 pinia狀態(tài)管理倉庫內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Vue3中如何使用SCSS編寫樣式

    Vue3中如何使用SCSS編寫樣式

    在Vue模板中啟用這些表現(xiàn)力庫插件的最簡單方法是在初始化項目時安裝它們,或使用 npm install(或 yarn add)安裝包,這篇文章主要介紹了Vue3中如何使用SCSS編寫樣式,需要的朋友可以參考下
    2023-12-12
  • vue-ls vue本地儲存的實例講解

    vue-ls vue本地儲存的實例講解

    這篇文章主要介紹了vue-ls vue本地儲存的實例講解,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • Vue3中列表拖拽排序的實現(xiàn)示例

    Vue3中列表拖拽排序的實現(xiàn)示例

    本文主要介紹了Vue3中列表拖拽排序的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-06-06
  • Vue取消Axios發(fā)出的請求

    Vue取消Axios發(fā)出的請求

    axios 是一個基于 promise 的 HTTP 庫,可以用在瀏覽器和 node.js 中。首先需要知道:axios不是一種新的技術(shù)。axios 是一個基于Promise 用于瀏覽器和 nodejs 的 HTTP 客戶端,本質(zhì)上也是對原生XHR的封裝,只不過它是Promise的實現(xiàn)版本,符合最新的ES規(guī)范
    2022-09-09
  • 關(guān)于this.$refs獲取不到dom的可能原因及解決方法

    關(guān)于this.$refs獲取不到dom的可能原因及解決方法

    這篇文章主要介紹了關(guān)于this.$refs獲取不到dom的可能原因及解決方法,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-11-11
  • vue動態(tài)生成dom并且自動綁定事件

    vue動態(tài)生成dom并且自動綁定事件

    本篇文章主要介紹了vue動態(tài)生成dom并且自動綁定事件,具有一定的參考價值,有興趣的可以了解一下。
    2017-04-04
  • vue中使用js-doc的案例代碼

    vue中使用js-doc的案例代碼

    這篇文章主要介紹了vue中使用js-doc的相關(guān)知識,本文結(jié)合實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2024-01-01
  • vue項目實現(xiàn)通過ip地址訪問和localhost訪問方式

    vue項目實現(xiàn)通過ip地址訪問和localhost訪問方式

    這篇文章主要介紹了vue項目實現(xiàn)通過ip地址訪問和localhost訪問方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • Vue 和 React 使用ref的示例詳解

    Vue 和 React 使用ref的示例詳解

    在 Vue 中,ref 是一個響應(yīng)式對象,修改 ref 的值會觸發(fā)組件的重新渲染,因為 Vue 的 ref 是基于其響應(yīng)式系統(tǒng)實現(xiàn)的,任何對 ref 的修改都會被 Vue 檢測到,并觸發(fā)組件的更新,本文給大家介紹Vue 和 React 使用ref的示例,感興趣的朋友一起看看吧
    2025-04-04
  • Vue?WebPack忽略指定文件或目錄方式

    Vue?WebPack忽略指定文件或目錄方式

    這篇文章主要介紹了Vue?WebPack忽略指定文件或目錄方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04

最新評論