Vuex 之 CreateMutation() Higher Order Function

栏目: JavaScript · 发布时间: 7年前

内容简介:實務上在寫 Vuex 時,由於 State 的修改都必須依賴 Mutation,因此 Mutation 寫出來的 code 都相當類似,此時可以建立Vue 2.5.17Vuex 3.0.1

實務上在寫 Vuex 時,由於 State 的修改都必須依賴 Mutation,因此 Mutation 寫出來的 code 都相當類似,此時可以建立 CreateMutation() Higher Order Function,專門負責建立 Mutation。

Version

Vue 2.5.17

Vuex 3.0.1

Vuex

store.js

import Vue from 'vue';
import Vuex from 'vuex';

Vue.use(Vuex);

/** state */
const state = {
  name: '',
};

/** mutations */
const setName = (state, payload) => state.name = payload;

const mutations = {
  setName,
};

export default new Vuex.Store({
  strict: true,
  state,
  mutations,
});

一個很典型的 Store 寫法。

12 行

const setName = (state, payload) => state.name = payload;

也是很典型的 mutation 寫法,由 payload 去寫入 name state。

實務上這種 code 將不斷地出現,差異只有 state 的部分,因此可以建立自己的 createMutation() Higher Order Function,專門建立這類 function。

createMutation()

vuex.js

export const createMutation = stateName => 
  (state, payload) => state[stateName] = payload;

createMutation() 傳入 stateName 之後,將回傳 (state, payload) => state[stateName] = payload function。

其中 name property 為變動的,可用 array [] 方式以變數取代。

store.js

import Vue from 'vue';
import Vuex from 'vuex';
import { createMutation } from "./helpers/vuex";

Vue.use(Vuex);

/** state */
const state = {
  name: '',
};

/** mutations */
const mutations = {
  setName: createMutation('name'),
};

export default new Vuex.Store({
  strict: true,
  state,
  mutations,
});

13 行

const mutations = {
  setName: createMutation('name'),
};

改用 createMutation() 建立 mutation 後,就相當清爽,只需傳入 state 名稱即可。

Conclusion

  • ECMAScript 的 Higher Order Function 非常好用,只要看到某些很類似的 function 重複出現,找出規則後,就可以使用 由 function 回傳 function 的特性,建立這些一直出現的 function

Sample Code

完整的範例可以在我的 GitHub 上找到


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

矩阵论

矩阵论

方保镕 / 清华大学出版社 / 2004-1 / 39.00元

本书比较全面、系统地介绍了矩阵的基本理论、方法及其应用。全书分上、下两篇,共10章,分别介绍了线性空间与线性算子,内积空间与等积变换,λ矩陈与若尔当标准形,赋范线性空间与矩阵范数,矩阵的微积分运算及其应用,广义逆矩阵及其应用,矩阵的分解,矩阵的克罗内克积、阿达马积与反积,几类特殊矩阵(如:非负矩阵与正矩阵、循环矩阵与素矩阵、随机矩阵和双随机矩阵、单调矩阵、M矩阵与H矩阵、T矩阵与汉大象尔矩阵等),......一起来看看 《矩阵论》 这本书的介绍吧!

MD5 加密
MD5 加密

MD5 加密工具

XML、JSON 在线转换
XML、JSON 在线转换

在线XML、JSON转换工具

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具