我正在开发一个 React/Redux 应用程序,它允许将“小部件”添加到页面并在 2D 空间中进行操作。要求可以同时选择和操作多个小部件。我当前状态树的简化版本如下所示......
{
widgets: {
widget_1: { x: 100, y: 200 },
widget_2: { x: 300, y: 400 },
widget_3: { x: 500, y: 600 }
},
selection: {
widgets: [ "widget_1", "widget_3" ]
}
}
我目前有这棵树由 2 个减速器管理,一个管理widgets
状态,另一个管理selection
状态。选择状态减少器可以简化为(注意:我也在使用 Immutable.js)...
currentlySelectedWidgets(state = EMPTY_SELECTION, action) {
switch (action.type) {
case SET_SELECTION:
return state.set('widgets' , List(action.ids));
default:
return state
}
}
这一切似乎都很有效,但我现在有一个要求,我正在努力适应这个模型......
出于 UI 目的,我需要让当前选择具有 x/y 属性,该属性反映当前选定小部件的左上角 x/y 坐标。一个示例状态可能看起来像......
{
widgets: {
widget_1: { x: 100, y: 200 },
widget_2: { x: 300, y: 400 },
widget_3: { x: 500, y: 600 }
},
selection: {
x: 100,
y: 200,
widgets: [ "widget_1", "widget_3" ]
}
}
这里的逻辑相当简单,例如找到min()
所有选定的小部件x
和y
值的 ,但我不确定我应该如何在减速器组合方面处理这个问题,因为currentlySelectedWidgets
减速器无法访问widgets
状态树的一部分。我考虑过...
- 将减速器合并为一个减速器:这似乎不是一个很好的可扩展解决方案。
- 将当前的小部件列表与操作一起传递:这似乎特别讨厌。
- 找到一种更好的方法来建模状态树:我有一个想法,但任何替代版本似乎都有其他缺点。
- 构建一个
combineReducers()
可以将小部件列表currentlySelectedWidgets()
作为附加参数提供给我的减速器的自定义:我认为这可能是我最好的选择。
我很想听到关于其他人如何管理类似情况的任何其他建议,似乎管理“当前选择”必须是其他人必须解决的常见状态问题。