Vuex 之 CreateMutation() Higher Order Function
栏目: JavaScript · 发布时间: 6年前
内容简介:實務上在寫 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 上找到
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
数据挖掘导论
Pang-Ning Tan, Michael Steinbach / 范明 范宏建 / 人民邮电出版社 / 2006-01-01 / 49.00元
本书全面介绍了数据挖掘的理论和方法,旨在为读者提供将数据挖掘应用于实际问题所必需的知识。本书涵盖五个主题:数据、分类、关联分析、聚类和异常检测。除异常检测外,每个主题都包含两章:前面一章讲述基本概念、代表性算法和评估技术,后面一章较深入地讨论高级概念和算法。目的是使读者在透彻地理解数据挖掘基础的同时,还能了解更多重要的高级主题。此外,书中还提供了大量示例、图表和习题。 本书适合作为......一起来看看 《数据挖掘导论》 这本书的介绍吧!