如果不同的化简器与同一动作相关联并且正在对商店进行更改,那么在进行任何编辑之前,它们是否收到了相同的版本?有优先考虑的地方吗?
例:
假设您在服务器端调度了一个动作Update
以编辑实体,一旦成功更新数据,效果将调度一个Update_Success
动作,并将新接收到的实体版本的实例作为有效负载。第一个经典的逻辑化约简器将使用它来更新商店:
case ItemActionTypes.UPDATE_ITEM_SUCCESS: {
const item = action.payload;
return {
...adapter.upsertOne(item, state),
loaded: true,
loading: false
};
}
现在假设在另一个文件中,您具有与同一操作关联的另一个化简器,并且需要将新接收的实体与商店中的旧实体进行比较:
case ItemActionTypes.UPDATE_ITEM_SUCCESS: {
const item = action.payload;
const oldItem = state.entities[item.id];
const changes = getAffectedProperties(item, oldItem);
// ...
}
问题是:
oldItem
是否有可能实际上保存了新接收的项目而不是旧的项目,因为第一个化简器可能已经对其进行了更新?是先到先得案吗?还是在实现上有什么保证所有的reducer都对同一版本的商店进行更改,并可能将这些更改进一步合并? 最佳答案
如果不同的异径管与同一动作相关联并且是
对商店进行更改,他们是否收到相同的版本
进行任何编辑之前?有优先考虑的地方吗?
减速器只能访问其状态。因此,您不应该真正在乎这一点。
同样,在分派一个动作时,所有减速器都以同步方式调用。这意味着,对于ACTION_A
,如果您要从不同的地方(/不同的缩减器)修改商店,则选择器(甚至视图)将仅刷新一次。当该操作的所有更新都应用到商店时。
关于javascript - NgRx-针对商店的 reducer 优先级和执行顺序,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/51118683/