mutation
const mutation = {
  namespace: 'test2',
  initialState: {},
  reduers: {
    reducerConditionOne: (state, action) => state,
  },
  centers: {
    centerConditionOne: (action, centerUtils) => {},
  },
};或者
const mutation = {
  namespace: 'test2',
  initialState: {},
  reduers: (state, action) => ({
    reducerConditionOne: () => state,
  }),
  centers: (action, centerUtils) => ({
    centerConditionOne: () => {},
  }),
};结构定义
字段
类型
必填
namespace
string
是
initailState
any (except undefined)
是
reducers
object | function
否
centers
object | function
否
namepace
mutation 的命名空间,只能用字符串。同时也是 store getState 返回的 state 上的属性,即 combineReducers 参数的 reducer 名。
const mutations = [
  {
    namespace: 'counter',
    initialState: null,
    reducers: {
      test: state => state,
    },
  },
];
//combineReducer({
  //counter: state => state,
//});initialState
当前 mutation 的 reducers 第一个参数 state 的初始值,优先级低于 createStore 的参数 preloadState。
别名为 state,兼容 dva。
reducers
reducers 支持两种类型写法。reducers 最终会合成一个reducer,reducers 中的各项 reducer,相当于 switch 的一个条件。
- object方式- 这种方式跟 - dva的- model一样。- const mutation = { namespace: 'counter', initialState: { value: 0 }, reducers: { increment: state => { const { value } = state; return { ...state, value: value + 1, }; }, decrement: state => { const { value } = state; return { ...state, value: value - 1, }; }, }, };- 上面的 - reducers最终会转换成下面的等同效果的- reducer:- function coutner(state = { value: 0 }, action) { const { value } = state; switch (action.type) { case 'counter/increment': return { ...state, value: value + 1 }; case 'counter/decrement': return { ...state, value: value - 1 }; return; default: state; } }
- function方式- function方式的优点在于,提取了公共参数- state和- action。- const mutation = { namespace: 'counter', initialState: { value: 0 }, reducers: (state, action) => ({ increment: () => { const { value } = state; return { ...state, value: value + 1, }; }, decrement: () => { const { value } = state; return { ...state, value: value - 1, }; }, }), };- 函数模式的 reducers 请严格遵循下面的规则,只返回 reducers对象,不可以中途做任何操作,否则可能会报错,如下面的是强烈不建议的,因为每次 - dispatch都会触发所有- reducers。- const mutation = { namespace: 'counter', initialState: { value: 0 }, reducers: (state, action) => { //不可以在这里做赋值或者其他操作 const { value } = state; return { increment: () => { return { ...state, value: value + 1, }; }, decrement: () => { return { ...state, value: value - 1, }; }, }; }, };
centers
centers 跟 reducers 类似,centers 支持两种类型写法。centers 最终会合成一个center,centers 中的各项 center,相当于 switch 的一个条件。
函数模式的 centers 请严格遵循下面的规则,只返回 centers对象,不可以中途做任何操作,否则可能会报错。
center 参数 API ,看这里。
- object方式- const mutation = { namespace: 'counter', initialState: null, reducers: { increment_async: (action, centerUtils) => {}, decrement_async: (action, centerUtils) => {}, }, };
- function方式- const mutation = { namespace: 'counter', initialState: null, reducers: (action, centerUtils) => ({ increment_async: () => {}, decrement_async: () => {}, }), };
Last updated
Was this helpful?
