如何快速知道哪个 useSelector 导致了 React 组件重渲染?

2022-07-28 15:26:38 +08:00
 fstar

一堆 useSelector 。

试着用 ahooks 的 useWhyDidYouUpdate ,一个个传入 useSelector ,但没发现问题。

https://ahooks.js.org/zh-CN/hooks/use-why-did-you-update/

发现还有些自定义钩子。。我也怀疑有些封装为对象的没有用 shallowEqual 。

感觉可以封装一下 useSelector ,比较函数返回 false 时,debugger 一下,但又很麻烦。。。

2346 次点击
所在节点    React
14 条回复
sweetcola
2022-07-28 16:25:07 +08:00
https://github.com/reduxjs/redux-devtools

可以试试这个浏览器扩展看能不能解决
swirling
2022-07-28 16:33:20 +08:00
我一般删一半代码 直接二分法找...
Mark24
2022-07-28 16:34:35 +08:00
不用 Hooks ✅

这就是 hooks 的问题
fstar
2022-07-28 16:43:12 +08:00
不用 Hooks ✅
kyuuseiryuu
2022-07-28 18:32:03 +08:00
为什么这么在意渲染了几次
用 jquery 页面就只会渲染一次
kwrush
2022-07-28 22:06:09 +08:00
你得先确认是 useSelector 输出变了导致 rerender 不是其他原因,建议用 redux devtool 检查是哪个数据变了。另外严格模式下会渲染两次。另外重渲染和用不用 hook 有什么关系…
kwrush
2022-07-28 22:12:24 +08:00
@kwrush 还有 react devtool 的 profiler 可以查看组件重渲染的原因
AyaseEri
2022-07-29 09:28:38 +08:00
React DevTool Profile 一下。不过都用 React 了不应该是大胆的让它重渲染么。
iseki
2022-07-29 10:27:25 +08:00
为什么要关注重渲染的问题,出现性能问题了吗
qfdk
2022-07-29 13:03:37 +08:00
你需要用 whyDidYouRender 这个库. update 的那个也推荐换 render. React 重新渲染是因为 state 改变了 或者 props 改变了. 我感觉你应该从这个原理下手
qfdk
2022-07-29 13:10:06 +08:00
看了下文档 上面有提到 你的 useSelect ,网址贴给你 https://github.com/welldone-software/why-did-you-render
qdxb
2022-07-29 16:21:12 +08:00
大伙有没有讲解 React 渲染相关的文章推荐?配合 props 、useState 、useMemo 、useEffect 、useRef 这些属性的。
magicdawn
2022-07-30 11:17:11 +08:00
ragnaroks
2022-08-01 14:58:02 +08:00
除了楼上提及的包以外,在绝大部分情况下一定是有数据变更导致了重新渲染,两个对象的内容看起来一样不一定是同一个对象

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/869258

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX