一堆 useSelector 。
试着用 ahooks 的 useWhyDidYouUpdate ,一个个传入 useSelector ,但没发现问题。
https://ahooks.js.org/zh-CN/hooks/use-why-did-you-update/
发现还有些自定义钩子。。我也怀疑有些封装为对象的没有用 shallowEqual 。
感觉可以封装一下 useSelector ,比较函数返回 false 时,debugger 一下,但又很麻烦。。。
1
sweetcola 2022 年 7 月 28 日
|
2
swirling 2022 年 7 月 28 日
我一般删一半代码 直接二分法找...
|
3
Mark24 2022 年 7 月 28 日
不用 Hooks ✅
这就是 hooks 的问题 |
4
fstar OP 不用 Hooks ✅
|
5
Chemist 2022 年 7 月 28 日 via iPhone
为什么这么在意渲染了几次
用 jquery 页面就只会渲染一次 |
6
kwrush 2022 年 7 月 28 日 via iPhone
你得先确认是 useSelector 输出变了导致 rerender 不是其他原因,建议用 redux devtool 检查是哪个数据变了。另外严格模式下会渲染两次。另外重渲染和用不用 hook 有什么关系…
|
8
AyaseEri 2022 年 7 月 29 日
React DevTool Profile 一下。不过都用 React 了不应该是大胆的让它重渲染么。
|
9
iseki 2022 年 7 月 29 日 via Android
为什么要关注重渲染的问题,出现性能问题了吗
|
10
qfdk PRO 你需要用 whyDidYouRender 这个库. update 的那个也推荐换 render. React 重新渲染是因为 state 改变了 或者 props 改变了. 我感觉你应该从这个原理下手
|
11
qfdk PRO 看了下文档 上面有提到 你的 useSelect ,网址贴给你 https://github.com/welldone-software/why-did-you-render
|
12
qdxb 2022 年 7 月 29 日
大伙有没有讲解 React 渲染相关的文章推荐?配合 props 、useState 、useMemo 、useEffect 、useRef 这些属性的。
|
13
magicdawn 2022 年 7 月 30 日 via iPad
|
14
ragnaroks 2022 年 8 月 1 日
除了楼上提及的包以外,在绝大部分情况下一定是有数据变更导致了重新渲染,两个对象的内容看起来一样不一定是同一个对象
|