reactjs – 在redux中重复使用多个reducers的操作

前端之家收集整理的这篇文章主要介绍了reactjs – 在redux中重复使用多个reducers的操作前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
所以我正在研究一个大型的react / redux应用程序,并且非常满意它在redux中的管理状态有多么简单.我们使用“ducks”风格的方法来减少/动作/动作创建者以保持相对基于域的东西.此外,我们尝试保持ui状态与域相关联,并且大多数reducer具有类似的结构.它看起来像这样:
export default function home(state = initialState,action = {}) {
  switch (action.type) {
    case OPEN:
      return {
        ...state,ui: {
          ...state.ui,[action.key]: true
        }
      };
    case CLOSE:
      return {
        ...state,[action.key]: false
        }
      };
    case SELECT_TAB:
      return {
        ...state,ui: {
          selectedTab: action.selected
        }
      };
    default:
      return state;
  }
}

我们最终会为ui反复重复相同的操作,主要是切换和设置显示内容.有没有办法将基于域的ui保留在reducer中,而无需在每个reducer中为ui添加OPEN和CLOSE类型语句.也许我正在考虑的是redux中的反模式,但很想知道以前是否有人遇到过这类问题?

更新:

我喜欢下面列出的解决方案,但是如何将reducer扩展为包含ui reducer的类型.

combineReducers({ 
    home: {createUiReducer('home',initialState),...home}
})

这样,您可以使用基于嵌套域的ui而无需重复所有操作.不知道你会怎么做,因为你基本上是动态添加CASE语句.

那么你需要用前缀命名它们.如果你像大多数开发人员一样懒惰,那么创建一个帮助函数,它将为你生成reducer;)

像这个..

const createOpenCloseReducer = (prefix,initialState) => {
  const = ui = prefix + "_UI";

  return (state = initialState,action) => {
     switch(action.type) {
     case (prefix + "_CLOSE"):  
       return { ...state,[ui]: "CLOSED" }
     case (prefix + "_OPEN"):
       return { ...state,[ui]: "OPENED" }
     default: 
       return state
     }
  }
}

import { combineReducers,createStore } from 'redux';

const rootReducer = combineReducers({
   home: combineReducers({
      ui: createOpenCloseReducer("HOME",{ "HOME_UI": "CLOSED" }),data: someOtherHomeDataReducer
   }),someOther: createOpenCloseReducer("OTHER",{ "OTHER_UI": "CLOSED" })
})

store = createStore(rootReducer)

// use it..
store.dispatch({type: "HOME_CLOSE"})
store.dispatch({type: "OTHER_OPEN"})

// your state..
store.getState().home.ui // {HOME_UI: "CLOSED"}
store.getState().someOther // {OTHER_UI: "OPENED"}

猜你在找的React相关文章