gpt4 book ai didi

reactjs - React.memo 与 react-router-dom useLocation()

转载 作者:行者123 更新时间:2023-12-05 04:52:22 25 4
gpt4 key购买 nike

最近我发现我的 React 应用程序存在一些性能问题,经过一些研究我发现了 React Memo。一些训练示例正常工作,但是当将它连接到我的应用程序时它没有任何效果。我发现问题出在 useLocation 上。

const Table = React.memo(() => {

const location = useLocation();

return <div>something</div>

},(prevProps, nextProps) => {
return true //I dont want re-render this Component when parent component is re-rendered
})

没有 useLocation 它也可以工作,但我需要这个位置,因为基于这个位置,更具体地说是基于来自这个位置的过滤器,我调用 API 数据。有点像

const location = useLocation();
useEffect(() => {
dispatch(getData(location.search))
}, [location]);

有人有更好的解决方案或一些提示吗?

最佳答案

解决这个问题的方法是创建一个包装器,将位置作为 prop 传入。这样做将使表成为一个纯组件,并且只会在位置发生变化时重新呈现。

function TableWrapper(){
const location = useLocation()

return <Table location={location} />
}

那么 table 需要有 location 作为 prop

const Table = React.memo(({location}) => {
return <div>something</div>
})

关于reactjs - React.memo 与 react-router-dom useLocation(),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/66531563/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com