Redux useSelector 对对象进行过滤?

Jon*_*ynn 3 javascript reactjs redux react-redux react-hooks

所以我使用 redux 和 useSelector 钩子从存储中获取数据。

我可以过滤reducer数组中的特定数据,以便组件仅在过滤后的数据更改时更新,例如:

const images = useSelector(state => state.Reducer.images.filter(x => x.id === someID));
Run Code Online (Sandbox Code Playgroud)

但是,当我对对象尝试相同类型的操作时,即使存储甚至没有更改,组件也总是会重新渲染。例如:

const images = useSelector(state => Object.keys(state.Reducer.images)
  .filter(x => x === someID)
  .reduce((arr, key) => {
    arr.push(state.Reducer.images[key].data);
    return arr;
  }, []));
Run Code Online (Sandbox Code Playgroud)

为什么会发生这种情况以及如何让它仅在数据更改时更新?假设将一些深度比较函数传递给 useSelector 吗?

jma*_*svt 6

您应该能够通过使用来避免这些重新渲染shallowEqual。这将防止新的引用始终被认为是不同的。

const images = useSelector(state => Object.keys(state.Reducer.images)
  .filter(x => x === someID)
  .reduce((arr, key) => {
    arr.push(state.Reducer.images[key].data);
    return arr;
  }, []), shallowEqual);
Run Code Online (Sandbox Code Playgroud)

https://react-redux.js.org/api/hooks#equality-comparisons-and-updates