詳解如何優(yōu)雅的進(jìn)行Vue的狀態(tài)管理
本篇文章將重點(diǎn)介紹以下幾個(gè)進(jìn)階使用方面:
- 輔助函數(shù):簡(jiǎn)化在 Vue 組件中使用 Vuex 的操作而提供的一組工具函數(shù)。
- 計(jì)算屬性:使用 getters 封裝復(fù)雜邏輯,使組件邏輯更清晰。
- 命名空間:詳解命名空間的作用和用法,避免模塊之間的命名沖突。
- 模塊化:將 Vuex 的狀態(tài)邏輯拆分成多個(gè)模塊,并實(shí)現(xiàn)模塊間的通信和協(xié)作。
通過(guò)學(xué)習(xí)本篇文章,你將進(jìn)一步掌握 Vuex 的進(jìn)階用法,提升對(duì) Vuex 的理解和運(yùn)用能力,更加優(yōu)雅的組織你的狀態(tài)管理樹!
一. 使用 Vuex 輔助函數(shù)
Vuex 輔助函數(shù)是為了簡(jiǎn)化在 Vue 組件中使用 Vuex 的操作而提供的一組工具函數(shù)。使用輔助函數(shù)可以簡(jiǎn)化對(duì) state、getters、mutations 和 actions 的訪問,減少了冗余的代碼和復(fù)雜的語(yǔ)法。
下面是常見的 Vuex 輔助函數(shù):
- mapState:簡(jiǎn)化狀態(tài)映射
- mapGetters:簡(jiǎn)化 getters 映射
- mapMutations:簡(jiǎn)化 mutations 映射
- mapActions:簡(jiǎn)化 actions 映射
1. mapState
mapState函數(shù)用于將 store 中的 state 映射到組件的計(jì)算屬性中,或者直接訪問這些 state 屬性。它接受一個(gè)數(shù)組或?qū)ο笞鳛閰?shù),用于指定要映射的 state 屬性名。
示例:
import { mapState } from 'vuex'
export default {
computed {
...mapState(['count'])
},
mounted () {
console.log(this.count)
},
}count 對(duì)應(yīng)的是 Vuex store 中的 state 屬性,通過(guò)使用mapState函數(shù),將count屬性映射到了組件的計(jì)算屬性中,可以使用 this 實(shí)例直接獲取到
2. mapGetters
mapGetters函數(shù)用于將 store 中的 getters 映射到組件的計(jì)算屬性中,或者直接訪問這些 getters。它接受一個(gè)數(shù)組或?qū)ο笞鳛閰?shù),用于指定要映射的 getters 函數(shù)名。
示例:
import { mapGetters } from "vuex";
export default {
computed: {
...mapGetters(["count"]),
},
};count 對(duì)應(yīng)的是 Vuex store 中的 getter 函數(shù),通過(guò)使用mapGetters函數(shù),將count函數(shù)映射到了組件的計(jì)算屬性中。
3. mapMutations
mapMutations 函數(shù)用于將 store 中的 mutations 映射到組件的方法中,以便組件可以直接調(diào)用commit來(lái)觸發(fā) mutations。它接受一個(gè)數(shù)組或?qū)ο笞鳛閰?shù),用于指定要映射的 mutations 函數(shù)名。
示例:
import { mapMutations } from "vuex";
export default {
methods: {
...mapMutations(["increment"]),
},
};increment 對(duì)應(yīng)的是 Vuex store 中的 mutation 函數(shù),通過(guò)使用mapMutations函數(shù),將increment函數(shù)映射到了組件的方法中。
4. mapActions
mapActions函數(shù)用于將 store 中的 actions 映射到組件的方法中,以便組件可以直接調(diào)用dispatch來(lái)觸發(fā) actions。它接受一個(gè)數(shù)組或?qū)ο笞鳛閰?shù),用于指定要映射的 actions 函數(shù)名。
示例:
import { mapActions } from "vuex";
export default {
methods: {
...mapActions(["incrementAsync"]),
},
};incrementAsync對(duì)應(yīng)的是 Vuex store 中的 action 函數(shù),通過(guò)使用mapActions函數(shù),我們將incrementAsync函數(shù)映射到了組件的方法中。
Vuex 輔助函數(shù)的使用可以簡(jiǎn)化在組件中對(duì) Vuex 的調(diào)用和使用,使代碼更加簡(jiǎn)潔和可讀。通過(guò)使用這些輔助函數(shù),我們可以更方便地訪問和操作 store 中的 state、getters、mutations 和 actions。
二. 使用 getters 計(jì)算屬性
1. getters 的作用
在 Vuex 中,getters 是用于獲取狀態(tài)的計(jì)算屬性,類似于組件中的計(jì)算屬性。它們可以對(duì) Vuex 中的狀態(tài)進(jìn)行處理、篩選或組合,并以一種響應(yīng)式的方式提供新的派生狀態(tài)。
getters 的作用是從 store 中獲取數(shù)據(jù),并以一種經(jīng)過(guò)處理的形式進(jìn)行展示或使用。在組件中使用 getters 可以方便地獲取所需的狀態(tài),而不需要在組件內(nèi)部重復(fù)編寫邏輯。
2. getters 的使用步驟
定義 getters
在 Vuex 的模塊配置中,可以使用 getters 字段定義 getters。
const store = new Vuex.Store({
state: { ... },
mutations: { ... },
actions: { ... },
getters: {
computedState: state => {
// 處理 state 并返回派生狀態(tài)的計(jì)算屬性
return state.someData + 10
},
filteredData: state => {
// 根據(jù)條件篩選 state 中的數(shù)據(jù)并返回派生狀態(tài)
return state.data.filter(item => item.condition === true)
}
}
})以上我們定義了兩個(gè) getters,分別是 computedState 和 filteredData。
使用 getters
在組件中可以使用 mapGetters 輔助函數(shù)或使用 $store.getters 來(lái)訪問 getters 的值。
import { mapGetters } from 'vuex'
export default {
computed: {
...mapGetters(['computedState', 'filteredData'])
},
mounted() {
console.log(this.computedState) // 輸出經(jīng)過(guò)處理的狀態(tài)值
console.log(this.filteredData) // 輸出經(jīng)過(guò)篩選的數(shù)據(jù)數(shù)組
console.log(this.$store.getters.computedState) // 通過(guò) $store.getters 訪問
}
}在上面的代碼中,我們使用 mapGetters 輔助函數(shù)將 getters 映射到組件的計(jì)算屬性中,然后可以在組件中直接使用。
3. getters 的優(yōu)勢(shì)
Vuex 的 getters 在狀態(tài)管理中具有以下幾個(gè)優(yōu)勢(shì):
統(tǒng)一管理計(jì)算屬性:有時(shí)需要根據(jù)一些狀態(tài)值進(jìn)行一些復(fù)雜的計(jì)算,例如對(duì)狀態(tài)進(jìn)行過(guò)濾、組合、轉(zhuǎn)換等操作,而 getters 可以讓我們統(tǒng)一管理這些計(jì)算屬性。通過(guò)將計(jì)算邏輯放在 getters 中,可以使代碼更具可維護(hù)性和可讀性。
響應(yīng)式更新:Vuex 的 getters 是響應(yīng)式的,當(dāng)所依賴的狀態(tài)發(fā)生變化時(shí),getters 會(huì)自動(dòng)重新計(jì)算。這意味著當(dāng) getters 所依賴的狀態(tài)發(fā)生變化時(shí),相關(guān)組件也會(huì)自動(dòng)更新。這樣可以避免手動(dòng)監(jiān)聽狀態(tài)的變化或手動(dòng)觸發(fā)計(jì)算屬性的更新。
避免重復(fù)計(jì)算:Vuex 對(duì) getters 進(jìn)行了緩存優(yōu)化。只有在 getters 所依賴的狀態(tài)發(fā)生變化時(shí),getters 才會(huì)重新計(jì)算。這樣可以避免不必要的計(jì)算開銷。而且,如果 getters 的值沒有發(fā)生變化,多次訪問它將會(huì)直接從緩存中讀取。這在某些情況下可以提升性能。
封裝復(fù)雜邏輯:有時(shí)候,某些狀態(tài)間的處理邏輯可能比較復(fù)雜,涉及多個(gè)模塊或多個(gè)狀態(tài)之間的交互。通過(guò)使用 getters,可以將這些復(fù)雜邏輯封裝到一個(gè)單獨(dú)的地方,使組件邏輯更清晰,減少代碼的冗余和重復(fù)。
Vuex 的 getters 在狀態(tài)管理中起到了統(tǒng)一管理計(jì)算屬性、實(shí)現(xiàn)響應(yīng)式更新、避免重復(fù)計(jì)算、封裝復(fù)雜邏輯、提高可復(fù)用性和可測(cè)試性的作用。它們?yōu)殚_發(fā)者提供了一種方便且強(qiáng)大的方式來(lái)處理和展示狀態(tài),使得應(yīng)用程序的狀態(tài)管理更加簡(jiǎn)潔、可維護(hù)和高效。
三. 命名空間
1. 什么是命名空間
在 Vuex 中,命名空間(namespaces)是一種組織和隔離模塊的方式,用于避免模塊之間的命名沖突。
命名空間為每個(gè)模塊提供了一個(gè)層級(jí)根,使得模塊的狀態(tài)、行為、和 getter 可以通過(guò)命名空間進(jìn)行訪問。這樣,就可以在模塊的路徑前加上命名空間前綴,來(lái)確保模塊的所有內(nèi)容是唯一且不會(huì)與其他模塊產(chǎn)生沖突。
2. 如何使用命名空間
- 定義命名空間:
在模塊中,可以通過(guò)在模塊配置中設(shè)置 namespaced: true 來(lái)定義命名空間。例如:
const store = new Vuex.Store({
modules: {
myModule: {
namespaced: true,
state: { ... },
mutations: { ... },
actions: { ... },
getters: { ... }
}
}
})以上代碼是我們將名為 myModule 的模塊設(shè)置為命名空間模塊。
- 使用命名空間:
使用命名空間時(shí),可以通過(guò)在訪問模塊的內(nèi)容之前添加命名空間前綴來(lái)引用模塊的狀態(tài)、行為和 getter。例如:
// 訪問命名空間模塊的狀態(tài)
store.state.myModule.stateName;
// 調(diào)用命名空間模塊的 mutation
store.commit("myModule/mutationName", payload);
// 調(diào)用命名空間模塊的 action
store.dispatch("myModule/actionName", payload);
// 獲取命名空間塊的 getter
store.getters["myModule/getterName"];如上所示,我們使用命名空間前綴 myModule/ 來(lái)訪問和調(diào)用模塊的狀態(tài)、行為和 getter。
命名空間的使用使得模塊之間的關(guān)系更為清晰,并可以避免命名沖突。但是請(qǐng)注意:在使用命名空間時(shí)需要小心,確保正確地引用和調(diào)用模塊的內(nèi)容。
四. 模塊化管理
1. 模塊化組織結(jié)構(gòu)
在 Vuex 中,可以使用模塊化的組織結(jié)構(gòu)來(lái)管理大型的狀態(tài)管理。模塊化能夠?qū)⒄麄€(gè)應(yīng)用的狀態(tài)分割為多個(gè)小模塊,每個(gè)模塊都有自己的 state、mutations、getters 和 actions。
以下是 Vuex 中最簡(jiǎn)單模塊化組織結(jié)構(gòu):
├── index.html
├── main.js
├── components // 組件
└── store
├── index.js # 組裝模塊并導(dǎo)出 store 的主文件
└── modules
├── moduleA.js # moduleA 模塊
└── moduleB.js # moduleB 模塊(1)定義 moduleA 模塊
// 創(chuàng)建一個(gè)模塊A
const moduleA = {
state: {
count: 0,
},
mutations: {
increment(state) {
state.count++;
},
},
actions: {
incrementAsync({ commit }) {
setTimeout(() => {
commit("increment");
}, 1000);
},
},
getters: {
doubleCount(state) {
return state.count * 2;
},
},
};
export default moduleA;(3)引入所用模塊,并創(chuàng)建Vuex實(shí)例
import Vue from "vue";
import Vuex from "vuex";
import moduleA from "moduleA";
import moduleB from "moduleB";
Vue.use(Vuex);
// 創(chuàng)建Vuex實(shí)例
const store = new Vuex.Store({
modules: {
moduleA,
moduleB,
},
});
export default store;上述示例中,我們定義了兩個(gè)模塊:moduleA 和 moduleB。每個(gè)模塊有自己的 state、mutations、actions 和 getters。在創(chuàng)建 Vuex 實(shí)例時(shí),將這些模塊對(duì)象放入modules選項(xiàng)中。
在組件中使用模塊化的狀態(tài)時(shí),可以通過(guò)輔助函數(shù)mapState、mapMutations、mapActions和mapGetters來(lái)簡(jiǎn)化使用:
import { mapState, mapMutations, mapActions, mapGetters } from "vuex";
export default {
computed: {
...mapState("moduleA", {
countA: "count",
}),
...mapState("moduleB", {
nameB: "name",
}),
...mapGetters("moduleA", ["doubleCount"]),
},
methods: {
...mapMutations("moduleA", ["increment"]),
...mapActions("moduleA", ["incrementAsync"]),
...mapMutations("moduleB", ["changeName"]),
},
};在上述示例中,通過(guò)指定模塊名,我們可以將模塊中的狀態(tài)和操作映射到組件的計(jì)算屬性和方法中。通過(guò)mapState可以將模塊 A 中的count映射為countA計(jì)算屬性,通過(guò)Mutations和mapActions可以將模塊 A 中的increment和incrementAsync映射為組件的方法。
通過(guò)模塊化組織結(jié)構(gòu),可以更好地管理和維護(hù)大型應(yīng)用的狀態(tài),使得狀態(tài)結(jié)構(gòu)更加清晰和可維護(hù)。模塊化還可以方便地復(fù)用模塊,將模塊拆分為多個(gè)文件進(jìn)行管理,提高開發(fā)效率。
注意:在模塊內(nèi)部的 mutations 和 getters 中,可以使用
rootState和rootGetters參數(shù)來(lái)訪問根模塊中的狀態(tài)和 getters。例如,在 moduleA 的 mutations 中可以使用rootState.moduleB.name來(lái)獲取 moduleB 中的 name 狀態(tài)。
2. 使用模塊化的優(yōu)勢(shì)
代碼分離和組織:將 Vuex 的狀態(tài)邏輯分割成多個(gè)模塊,可以更好地組織代碼,提高代碼的可維護(hù)性和可讀性。每個(gè)模塊都有自己的狀態(tài)、操作和獲取器,使得代碼更加清晰和可擴(kuò)展。
避免命名沖突:使用模塊化可以避免全局狀態(tài)中的命名沖突問題。每個(gè)模塊都有己的命名空間防止了不同模塊之間的命名沖突,提高了代碼的健壯性和穩(wěn)定性。
提高可復(fù)用性:模塊化的設(shè)計(jì)使得模塊可以在不同的應(yīng)用程序中被復(fù)用??梢詫⑼ㄓ玫臓顟B(tài)模塊封裝成獨(dú)立的模塊,然后在不同的應(yīng)用程序中引入并使用。
模塊獨(dú)立調(diào)試:每個(gè)模塊都可以獨(dú)立進(jìn)行狀態(tài)的修改和操作,方便調(diào)試。通過(guò)模塊化,可以更加精確地定位到問題所在,快速解決 bug。
3. 什么情況下需要使用模塊化
大型應(yīng)用程序:對(duì)于大型的 Vue.js 應(yīng)用程序,使用模塊化可以更好地組織和管理狀態(tài)。不同模塊可以分別負(fù)責(zé)處理不同的業(yè)務(wù)邏輯,使得代碼更清晰。
多人協(xié)作開發(fā):在多人協(xié)作開發(fā)的項(xiàng)目中,使用模塊化可以更好地分工合作。每個(gè)開發(fā)者可以負(fù)責(zé)一個(gè)或多個(gè)模塊的開發(fā)和維護(hù),減少了代碼沖突和影響范圍,提高了開發(fā)效率。
復(fù)雜的業(yè)務(wù)邏輯:對(duì)于復(fù)雜的業(yè)務(wù)邏輯,使用模塊化可以將其拆分成多個(gè)獨(dú)立的模塊,使得代碼更易于理解和維護(hù)。每個(gè)模塊負(fù)責(zé)處理各自的邏輯,減少了耦合度。
可復(fù)用的模塊:如果有一些通用的狀態(tài)邏輯需要在不同的應(yīng)用程序中復(fù)用,可以將其封裝成獨(dú)立的模塊。這樣可以避免重復(fù)編寫代碼,提高了開發(fā)效率和代碼的可維護(hù)性。
Vuex 的模塊化設(shè)計(jì)使得代碼更加清晰、可維護(hù)性更高,并且有利于多人協(xié)作開發(fā)和復(fù)用狀態(tài)邏輯。在大型應(yīng)用程序或者需要拆分復(fù)雜業(yè)務(wù)邏輯的情況下,使用模塊化可以帶來(lái)諸多好處。
結(jié)語(yǔ)
在本篇文章中,我們介紹了 Vuex 的進(jìn)階使用,包括模塊化、命名空間以及高級(jí)選項(xiàng)等方面。通過(guò)這些進(jìn)階技巧,我們可以更好地組織和管理 Vuex 的狀態(tài)管理。
模塊化是 Vuex 中非常重要的一個(gè)特性,通過(guò)將狀態(tài)拆分為多個(gè)模塊,我們可以更好地管理復(fù)雜的應(yīng)用程序狀態(tài)。從而更靈活地?cái)U(kuò)展和配置我們的狀態(tài)管理。命名空間則可以幫助我們解決模塊之間的命名沖突問題,并提供更清晰的語(yǔ)義。
通過(guò)掌握這些進(jìn)階技巧,我們可以更好地應(yīng)對(duì)復(fù)雜的狀態(tài)管理需求,并提高應(yīng)用程序的可維護(hù)性和開發(fā)效率。
以上就是詳解如何優(yōu)雅的進(jìn)行Vue的狀態(tài)管理的詳細(xì)內(nèi)容,更多關(guān)于Vue狀態(tài)管理的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
vue項(xiàng)目使用CDN引入的配置與易出錯(cuò)點(diǎn)
在日常開發(fā)過(guò)程中,為了減少最后打包出來(lái)的體積,我們會(huì)用到cdn引入一些比較大的庫(kù)來(lái)解決,下面這篇文章主要給大家介紹了關(guān)于vue項(xiàng)目使用CDN引入的配置與易出錯(cuò)點(diǎn)的相關(guān)資料,需要的朋友可以參考下2022-05-05
vue實(shí)現(xiàn)消息列表向上無(wú)縫滾動(dòng)效果
本文主要實(shí)現(xiàn)vue項(xiàng)目中,消息列表逐條向上無(wú)縫滾動(dòng),每條消息展示10秒后再滾動(dòng),為了保證用戶能看清消息主題,未使用第三方插件,本文實(shí)現(xiàn)方法比較簡(jiǎn)約,需要的朋友可以參考下2024-06-06
Vuejs+vue-router打包+Nginx配置的實(shí)例
今天小編就為大家分享一篇Vuejs+vue-router打包+Nginx配置的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-09-09
Vue使用Three.js創(chuàng)建交互式3D場(chǎng)景的全過(guò)程
在現(xiàn)代Web開發(fā)中,通過(guò)在頁(yè)面中嵌入3D場(chǎng)景,可以為用戶提供更加豐富和交互性的體驗(yàn),Three.js是一款強(qiáng)大的3D JavaScript庫(kù),它簡(jiǎn)化了在瀏覽器中創(chuàng)建復(fù)雜3D場(chǎng)景的過(guò)程,本文將介紹如何在Vue中使用Three.js,創(chuàng)建一個(gè)簡(jiǎn)單的交互式3D場(chǎng)景,需要的朋友可以參考下2023-11-11
使用vuex緩存數(shù)據(jù)并優(yōu)化自己的vuex-cache
這篇文章主要介紹了使用vuex緩存數(shù)據(jù)并優(yōu)化自己的vuex-cache,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-05-05
Ant?Design?Vue?走馬燈實(shí)現(xiàn)單頁(yè)多張圖片輪播效果
這篇文章主要介紹了Ant?Design?Vue?走馬燈實(shí)現(xiàn)單頁(yè)多張圖片輪播,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-07-07
解決vue中修改export default中腳本報(bào)一大堆錯(cuò)的問題
今天小編就為大家分享一篇解決vue中修改export default中腳本報(bào)一大堆錯(cuò)的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-08-08
vue-next-admin項(xiàng)目使用cdn加速詳細(xì)配置
這篇文章主要為大家介紹了vue-next-admin項(xiàng)目使用cdn加速的詳細(xì)配置,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-06-06

