隨着Vue
應用程序的大小增長,Vuex Store
中的actions
和mutations
也會增長。本文,咱們將介紹如何將其減小到易於管理的東西。javascript
Vuex是什麼
Vuex
是vue.js
應用程序的狀態管理模式+庫。它充當應用程序中全部組件的集中存儲,其規則確保狀態只能以可預測的方式進行變動。vue
咱們怎麼使用Vuex
咱們正在使用Vuex
在Factory Core Framework
應用程序中的全部應用程序之間共享狀態。因爲框架是一組應用程序,(假設)咱們目前有九個Vuex stores
。每一個store
都有本身的state, actions和mutations
。咱們在store
中使用actions
來對後臺進行API調用。數據返回後,咱們使用mutations
將其存儲在state
中。這容許任何組件訪問該數據。能夠想象到,咱們的store
能夠有大量的actions
來處理這些API調用。如下是咱們其中一個Vuex stores
中全部的actions
操做示例。java
這個store
有16個actions
。如今想象一下,若是咱們有9個store
,咱們的Factory Core Framework
總共有多少個actions
。ios
簡化咱們的Actions
咱們全部的actions
操做基本上都執行相同的功能。每一個action
都執行如下操做:git
- 從API獲取數據(必要時包括有效負載)
- 以
state
存儲數據(可選) - 返回對調用該
action
組件的響應
要將這些重構爲單個(統一)操做action
,咱們須要知道action
須要明確的事情:github
- 要擊中的端點(請求接口)
- 在API調用中是否發送有效負載
- 是否將數據提交到
state
中,若是是,則提交到哪一個狀態變量
咱們當前的action
下面是咱們其中的一個actions
示範:vuex
async getLineWorkOrders({ rootState, commit }, payload) {
try {
let response = await axios.post(
'api.factory.com/getLineWorkOrders',
Object.assign({}, payload.body, { language: rootState.authStore.currentLocale.locale }),
rootState.config.serviceHeaders
);
commit( 'setCurrentWorkOrderNumber', response.data.currentWorkOrderNumber );
return response.data;
} catch (error) {
throw error;
}
},
複製代碼
在這個action
中,咱們經過擊中端點(發起請求)api.factory.com/geteLineWorkOrders
從咱們的後臺API獲取數據。檢索到數據以後,將更新state
變量currentWorkOrder
。最後,數據將返回到進行調用的組件中。咱們全部的actions
都有這種格式。要將它重構爲單個操做,咱們須要擁有端點,不管是否發送有效負載以及是否提交數據。下面👇是咱們重構的單一action
:axios
async fetchData({ rootState, commit }, payload) {
try {
let body = { language: rootState.authStore.currentLocale.locale };
if (payload) {
body = Object.assign({}, payload.body, body);
}
let response = await axios.post(\`api.factory.com/${payload.url}\`, body, rootState.config.serviceHeaders ); if (payload.commit) { commit('mutate', { property: payload.stateProperty, with: response.data\[payload.stateProperty\] }); } return response.data; } catch (error) { throw error; } } 複製代碼
此單個action
將處理每種可能的調用。若是咱們須要經過API調用發送數據,它能夠作到。若是咱們須要commit
提交數據,它能夠作到。若是它不須要提交數據,則不會。它始終將數據返回到組件。api
使用統一的mutation
以前,對於須要改變狀態mutate state
的每一個action
,咱們建立了一個新的mutation
來處理這個問題。咱們使用單一的mutation
來處理這個問題。下面是咱們的單一mutation
:markdown
const mutations = {
mutate(state, payload) {
state\[payload.property\] = payload.with;
}
};
複製代碼
若是一個action
中須要在store
中存儲數據,咱們以下調用mutation
:
commit('mutate', {
property: <propertyNameHere>,
with: <valueGoesHere>
});
複製代碼
總結
經過統一咱們的action
和mutation
,咱們大大簡化了咱們的store
中的actions
和mutations
。
譯者加:其實就是爲了更好的管理vuex,而造成模版方式的編寫
後話
更多的內容,請戳個人博客進行了解,能留個star就更好了💨
個人博客即將同步至騰訊雲+社區,邀請你們一同入駐:cloud.tencent.com/developer/s…
本文同步分享在 博客「Jimmy」(JueJin)。
若有侵權,請聯繫 support@oschina.cn 刪除。
本文參與「OSC源創計劃」,歡迎正在閱讀的你也加入,一塊兒分享。