我编写了这段代码来创建 Redux store
:
import {combineReducers} from 'redux-immutable'
const MyAppReducers = combineReducers({
Node1: Node1Reducer,
Node2: Node2Reducer,
Node3: Node3Reducer,
Node4: Node4Reducer
})
let store = createStore(
MyAppReducers,
composeEnhancers(
applyMiddleware(
thunkMiddleware,
ApiMiddleware,
loggerMiddleware
)
)
)
此配置的结果是一个在Immutable.Map()
s 内的普通对象:
{
Node1: Immutable.Map(),
Node2: Immutable.Map(),
Node3: Immutable.Map(),
Node4: Immutable.Map()
}
相反,我希望所有状态树都是Immutable.Map()
.
所以我试图combineReducers()
直接传递给一个Immutable.Map()
对象:
const MyAppReducers = combineReducers(Immutable.Map({
Node1: Node1Reducer,
Node2: Node2Reducer,
Node3: Node3Reducer,
Node4: Node4Reducer
}))
但这会在控制台中引发错误:
未捕获的 TypeError:reducer 不是函数
在 combineReducers.js:39
在 Array.forEach ()
在 combineReducers.js:36
在 Map.withMutations (immutable.js:1353)
在 combineReducers.js:35
在 computeNextEntry (:2:27469)
在重新计算状态 (:2:27769)
在:2:31382
调度时(createStore.js:165)
在 createStore (createStore.js:240)
redux-immutable
我应该将 的initialState
作为函数的第二个参数传递的状态的文档createStore
,但我的第二个参数当前composeEnhancers
是我需要配置中间件和其他东西的函数。
如何使整个状态树成为一个Immutable.Map()
对象?