我刚开始使用normalizr来管理我的状态。我已经到了以下代码更新所需对象但我无法以干净,干燥的方式将它们合并回标准化状态的程度。这样做的首选方式是什么?
请原谅我的诺言,谢谢你的时间。
// normalized state
{
"entities": {
"items": {
"1": {
"id": 1,
"title": "Item 1",
},
"2": {
"id": 2,
"title": "Item 2",
},
"3": {
"id": 3,
"title": "Item 3",
},
},
"groups": {
"20": {
"id": 20,
"title": "Group 1",
"items": [ 1, 2 ]
},
"21": {
"id": 21,
"title": "Group 2",
"items": [ 3 ]
}
}
},
"result": [ 20, 21 ]
}
// actions
export const addItem = values => ({
type: ADD_ITEM,
payload: {...values, itemID: uuid.v1() }
// values come from a form
})
// reducer
const items = (state, action) => {
switch(action.type) {
case ADD_ITEM:
let { items } = state.entities;
let { itemID } = action.payload;
return {
...items,
[itemID]: {
id: itemID,
...item,
subItems:[]
}
}
default:
return state;
}
}
const groups = (state = initialState, action) => {
switch(action.type) {
case ADD_ITEM:
let { payload } = action;
let { groupID, itemID } = payload; // GroupID comes from form submit
let { groups } = state.entities;
return {
...groups,
[groupID]: [
...groups[groupID],
groups[groupID].items = [
...groups[groupID].items,
itemID
]
]
}
default:
return state;
}
}
export default groups;
答案 0 :(得分:0)
您必须使用Combine Reducer将所有这些实体合并为一种状态。如下代码:
import user from './user';
import contacts from './contacts';
import activeUser from './activeUser';
import messages from './messages';
import {combineReducers} from 'redux';
import typing from './typing';
export default combineReducers({
user,
contacts,
activeUser,
messages,
typing
});
查看完整的代码here