Redux + Normalizr 分离(删除)操作

标签 redux normalizr

我使用 redux 和 normalizr 来规范来自服务器的响应,基本上遵循 real-world例子。这样entities reducer 很简单,只需合并响应即可。我现在遇到的问题是 delete手术。我找到了这个 issue#21 of normalizr repo但仍然无法弄清楚如何解决这个问题。例如,

当前状态是

{
  entities:
    product_categories: {
      ...
      13: {
        ...
        products: ["1", "2"], <--------------- [i] Current state
        ...
      }
    },
    products: {
      1: {
        id: "1"
      }
    }
}

归一化响应是
{
  ...
    product_categories: {
      ...
      13: {
        ...
        products: ["1"], <---------------- [2] Normalized result
      }
  ...
}

如您所见,后端 api 仅返回 属于该类别的所有产品 ID ,在这种情况下,“2”是分离的。当“实体” reducer 合并此响应时,“2”仍然存在。现在我只是重新加载页面,但我想知道是否有更好的方法来处理这种情况?

entities reducer ,我只是像在现实世界中的例子一样合并它。
return merge({}, state, action.payload.entities);

最佳答案

只是不要担心它在那里。把你的状态想象成一个数据库。您也不会真正从数据库中删除记录以避免复杂的级联——通常您只是更改它们在数据库中的状态。同样,使用 Normalizer,不是真正删除实体,而是让它们在缓存中,直到用户离开页面!

关于Redux + Normalizr 分离(删除)操作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33727506/

相关文章:

javascript - React.js : Create resource with redux-form, 其余 api 和 async/await

reactjs - 无法通过 Jest ​​快照匹配

javascript - 为什么我有这个 Uncaught TypeError : (0 , _normalizr.arrayOf) is not a function?

javascript - Redux normalizr + 处理减少的响应

javascript - 使用 redux devtools(chrome 扩展)配置 redux store

reactjs - 是否不鼓励使用 Context 进行组件之间的通信?

javascript - 传播运算符覆盖新对象中的元素而不是组合

javascript - 标准化测验数据的问题

javascript - 如果路由不存在,React Router 添加条件

javascript - 使用 Normalizr 将非嵌套树标准化为嵌套树