React Hooks为什么要在顶层使用?

为什么必须在函数顶层使用hooks?

使用过 hooks 的小伙伴应该都会发现,hooks只能在函数式组件的顶层使用,不能在循环,条件或嵌套函数中调用 Hook。

为什么呢?

查阅了很多答案,总结如下:

hooks 是 react 16.8版本推出的,而react v16版本最大的改变就是引入了fiber架构。hooks的实现就是基于fiber的。每个组件都会生成一个 FiberNode(节点),组件内使用的 hook 会以链表的形式挂在 FiberNode 的 memoizedState 上面。各个 FiberNode 汇聚起来会变成一颗 Fiber 树,React 每次会以固定的顺序 遍历这棵树,这样就把整个页面的 hook 都串联起来了。

当 react 重新渲染时,会生成一个新的 fiber 树,而这里会根据之前已经生成的 FiberNode ,拿到之前的 hook ,再复制一份到新的 FiberNode 上,生成一个新的 hooks 链表。
react按顺序来区分不同的 hook,它默认你不会修改这个顺序。如果你没有在顶层使用 hook ,打乱了每次 hook 调用的顺序,就会导致 react 无法区分出对应的 hook

相关推荐
前端程序猿i8 分钟前
用本地代理 + ZIP 打包 + Excel 命名,优雅批量下载跨域 PDF
前端·javascript·vue.js·html
Danny_FD16 分钟前
Vue2 中使用vue-markdown实现编辑器
前端·javascript·vue.js
用户479492835691518 分钟前
字节面试官:forEach 为什么不能被中断?
前端·javascript
tager24 分钟前
🍪 让你从此告别“Cookie去哪儿了?”
前端·javascript·后端
程序员小续38 分钟前
再也不写 Class:React Hooks 完整实战与最佳实践
前端·javascript·react.js
芝士加43 分钟前
一个有趣的搜索神器:pinyin-match
前端·javascript·开源
一只大黑洋1 小时前
Clipboard.js 复制内容
前端·javascript·vue.js
然我1 小时前
从 “只会聊天” 到 “能办实事”:OpenAI Function Call 彻底重构 AI 交互逻辑(附完整接入指南)
前端·javascript·人工智能
鹏多多1 小时前
vue混入mixins详解和生命周期影响
前端·javascript·vue.js
汪子熙1 小时前
HTML 中的 Bidirectional Isolate (bdi) 元素深入解析
前端·javascript