Vuex中的getter和mutation的區(qū)別詳解
引言
在現(xiàn)代前端開發(fā)中,狀態(tài)管理是一個(gè)不可忽視的話題,而Vuex作為Vue.js的官方狀態(tài)管理庫(kù),在大型應(yīng)用中扮演著至關(guān)重要的角色。當(dāng)我們使用Vuex進(jìn)行狀態(tài)管理時(shí),getter和mutation是兩個(gè)重要的概念。雖然它們都是用來處理狀態(tài)的,但是它們的功能和使用場(chǎng)景卻大相徑庭。在本文中,我們將詳細(xì)探討getter和mutation的區(qū)別,并通過示例代碼幫助理解。
1. 何為Mutation?
Mutation是Vuex中用于更改狀態(tài)的方法。它不能是異步的,因此所有的狀態(tài)修改都需要在mutation中以同步的方式完成。Mutation的作用是負(fù)責(zé)維護(hù)狀態(tài)的一致性。在Vuex中,每個(gè)mutation都有一個(gè)字符串類型的事件類型和一個(gè)回調(diào)函數(shù),該回調(diào)函數(shù)會(huì)接受當(dāng)前的狀態(tài)和負(fù)載(payload)作為參數(shù)。
1.1 Mutation 示例代碼
我們以一個(gè)簡(jiǎn)單的計(jì)數(shù)器示例來說明mutation的使用。首先,我們來創(chuàng)建Vuex的store并定義一個(gè)mutation。
import Vue from 'vue'; import Vuex from 'vuex'; Vue.use(Vuex); const store = new Vuex.Store({ state: { count: 0 }, mutations: { increment(state) { state.count++; }, decrement(state) { state.count--; }, setCount(state, payload) { state.count = payload; } } });
在這個(gè)示例中,我們有一個(gè)count狀態(tài),并定義了三個(gè)mutations:increment、decrement和setCount。這三個(gè)方法都是用來修改狀態(tài)的。你可以通過store.commit方法來調(diào)用這些mutations。
1.2 調(diào)用Mutation
我們可以在組件中調(diào)用mutation,如下所示:
<template> <div> <p>Count: {{ count }}</p> <button @click="increment">Increment</button> <button @click="decrement">Decrement</button> <button @click="reset">Set Count to 10</button> </div> </template> <script> export default { computed: { count() { return this.$store.state.count; } }, methods: { increment() { this.$store.commit('increment'); }, decrement() { this.$store.commit('decrement'); }, reset() { this.$store.commit('setCount', 10); } } }; </script>
在這個(gè)組件中,我們通過this.$store.commit
調(diào)用定義好的mutations,來增加、減少或重置計(jì)數(shù)。
2. 何為Getter?
Getter是Vuex提供的用于獲取狀態(tài)的計(jì)算屬性。它們的功能有點(diǎn)類似于Vue的計(jì)算屬性,它們可以基于store中的狀態(tài)計(jì)算出一些派生狀態(tài)。Getter不僅可以讀取狀態(tài),還可以使用輸入?yún)?shù)并返回加工后的狀態(tài)值。
2.1 Getter 示例代碼
在我們的計(jì)數(shù)器示例中,我們可以添加一個(gè)getter來獲取當(dāng)前計(jì)數(shù)的平方值。
const store = new Vuex.Store({ state: { count: 0 }, mutations: { increment(state) { state.count++; }, decrement(state) { state.count--; }, setCount(state, payload) { state.count = payload; } }, getters: { squareCount(state) { return state.count * state.count; } } });
在這個(gè)示例中,我們定義了一個(gè)gettersquareCount
,它返回count
狀態(tài)的平方值。
2.2 使用Getter
在組件中,我們可以像使用計(jì)算屬性一樣使用getter:
<template> <div> <p>Count: {{ count }}</p> <p>Square Count: {{ squareCount }}</p> <button @click="increment">Increment</button> <button @click="decrement">Decrement</button> <button @click="reset">Set Count to 10</button> </div> </template> <script> export default { computed: { count() { return this.$store.state.count; }, squareCount() { return this.$store.getters.squareCount; } }, methods: { increment() { this.$store.commit('increment'); }, decrement() { this.$store.commit('decrement'); }, reset() { this.$store.commit('setCount', 10); } } }; </script>
在這個(gè)組件中,我們通過this.$store.getters.squareCount
獲取到當(dāng)前計(jì)數(shù)的平方值并展示在視圖中。
3. Getter與Mutation的主要區(qū)別
3.1 功能不同
- Mutation: 用于更改狀態(tài),必須是同步的,專注于更新store中的數(shù)據(jù)。
- Getter: 用于獲取狀態(tài)的派生值,可以基于state生成新值,也可以接受參數(shù),通常用于對(duì)狀態(tài)的計(jì)算和過濾操作。
3.2 使用方式不同
- Mutation: 使用
store.commit
來調(diào)用。 - Getter: 使用
store.getters
來獲取。
3.3 同步與異步
- Mutation: 必須是同步,所有狀態(tài)變化都要在Mutation中完成,上層組件的狀態(tài)反應(yīng)也是同步的。
- Getter: 可以從狀態(tài)中計(jì)算出派生狀態(tài),通常是通過對(duì)狀態(tài)值的運(yùn)算得出。
3.4 使用場(chǎng)景不同
- Mutation: 用于響應(yīng)用戶的操作,例如點(diǎn)擊按鈕后增加計(jì)數(shù),需要更改狀態(tài)。
- Getter: 用于獲取狀態(tài)的計(jì)算結(jié)果,例如顯示某個(gè)狀態(tài)的平方、和或其他派生數(shù)據(jù)。
結(jié)論
在Vuex中,有效地區(qū)分getter和mutation是使用狀態(tài)管理的基礎(chǔ)。在復(fù)雜的應(yīng)用中,準(zhǔn)確地管理狀態(tài)與數(shù)據(jù)流至關(guān)重要。我們通過例子理解了getter和mutation的定義、用法以及它們之間的核心區(qū)別。在日常開發(fā)中,務(wù)必注意這兩者的功能劃分,以保持代碼的整潔與可維護(hù)性。
以上就是Vuex中的getter和mutation的區(qū)別詳解的詳細(xì)內(nèi)容,更多關(guān)于Vuex getter和mutation區(qū)別的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
詳解關(guān)于表格合并span-method方法的補(bǔ)充(表格數(shù)據(jù)由后臺(tái)動(dòng)態(tài)返回)
這篇文章主要介紹了詳解關(guān)于表格合并span-method方法的補(bǔ)充(表格數(shù)據(jù)由后臺(tái)動(dòng)態(tài)返回) ,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2019-05-05基于vue3開發(fā)mobile-table適用于移動(dòng)端表格
這篇文章主要給大家介紹了關(guān)于如何基于vue3開發(fā)mobile-table適用于移動(dòng)端表格的相關(guān)資料,需要的朋友可以參考下2024-03-03在Vue項(xiàng)目中,防止頁(yè)面被縮放和放大示例
今天小編就為大家分享一篇在Vue項(xiàng)目中,防止頁(yè)面被縮放和放大示例,具有很好的參考 價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-10-10Vue+element+cookie記住密碼功能的簡(jiǎn)單實(shí)現(xiàn)方法
這篇文章主要給大家介紹了Vue+element+cookie記住密碼功能的簡(jiǎn)單實(shí)現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-09-09Vue導(dǎo)入excel表,導(dǎo)入失敗的數(shù)據(jù)自動(dòng)下載
本文詳細(xì)講解了Vue導(dǎo)入excel表,導(dǎo)入失敗的數(shù)據(jù)自動(dòng)下載的方法,文中通過示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-11-11詳解vue3?響應(yīng)式的實(shí)現(xiàn)原理
Vue.js?3.0?為了解決?Object.defineProperty?的這些缺陷,使用?Proxy?API?重寫了響應(yīng)式部分,并獨(dú)立維護(hù)和發(fā)布整個(gè)?reactivity?庫(kù),這篇文章主要介紹了vue3?響應(yīng)式的實(shí)現(xiàn)原理,需要的朋友可以參考下2022-06-06Vue3使用Univer Docs創(chuàng)建在線編輯Excel的示例代碼
本文介紹了如何在Vue3項(xiàng)目中集成UniverDocs,一個(gè)基于Luckysheet的企業(yè)文檔與數(shù)據(jù)協(xié)同解決方案,指導(dǎo)了從安裝到在頁(yè)面中使用的步驟,以及注意事項(xiàng),如數(shù)據(jù)格式轉(zhuǎn)換和二次開發(fā)的靈活性,需要的朋友可以參考下2025-04-04