以为 Hooks 是银弹,结果是新坑

关于 React Hooks 的一些真心话------它可能没你想的那么优雅

今天想和大家聊一个熟悉又陌生的东西------React Hooks。

Hooks 出来也有好几年了,现在几乎已经是 React 开发的"标配"。很多人说它好用,说它优雅,说它是未来。

但说实话,用久了之后,我发现 Hooks 其实有不少"坑",有些设计甚至有点"反人类"。今天就来坦诚地聊聊这些问题。


一、Hooks 有一些"奇怪"的规矩 🤔

1. 命名必须用 use 开头

比如 useStateuseEffect......看似统一,但其实很模糊。 你看到 useGetData,能马上分辨它是副作用?是同步逻辑?还是纯函数?并不直观。

相比之下,Class 组件里 fetchDatahandleClick 这样的命名,一眼就能看懂。


2. 调用顺序必须一致

Hooks 的内部实现依赖 调用顺序,而不是变量名。

js 复制代码
const [name, setName] = useState('小明')
const [age, setAge] = useState(18)

React 怎么区分 nameage? 答案是:先调用的先存,后调用的后存

这就导致了一个限制:绝对不能在条件语句或循环里写 Hook

js 复制代码
if (condition) {
  const [value, setValue] = useState(null) // ❌ 状态顺序会乱
}

这简直是"靠开发者自觉"去维护,一不小心就埋雷。


二、useRef:万能的救星还是"邪术"?🌀

useRef 的初衷是获取 DOM 节点,但因为它能跨渲染保存引用,很多人直接拿它当 "跨渲染变量"

js 复制代码
const countRef = useRef(0)

问题是:这样你就 打破了函数组件的纯函数特性 。 这和 class 里的 this 几乎没区别,但 this 至少是显式的,而 useRef 更隐蔽。

久而久之,项目里到处都是 xxxRef,比 class 组件还乱。


三、useEffect:混乱的副作用大师 🎭

useEffect 本来是为了解决副作用,但实际用起来经常让人困惑。

js 复制代码
useEffect(() => {
  // 你以为只会在 a 变化时执行?
}, [a])

如果你写了 Date.now() 这样的值在依赖里,它每次渲染都会触发。 更"神奇"的是,默认不写依赖就会在每次渲染后执行。

很多人还得写个空数组 [] 来模拟 componentDidMount

js 复制代码
useEffect(() => {
  // 相当于 didMount
}, [])

结果:一个 API 承担了太多功能,反而让人更容易误用。


四、useCallback:优化还是负担?⚡

很多人用 useCallback 来避免子组件重复渲染:

js 复制代码
const handleClick = useCallback(() => {
  console.log('clicked')
}, [])

但一旦依赖写错,就容易踩坑:

js 复制代码
const [count, setCount] = useState(0)

// ❌ 漏了依赖 count
const handleClick = useCallback(() => {
  console.log(count) // 永远是 0
}, [])

这种 bug 隐蔽又难查,让人怀疑人生。 于是你可能花比"优化"更多的时间在修 bug。


五、自定义 Hooks:万物皆可 use?🧩

现在社区里各种 Hook 满天飞:useRequestuseToggleuseCookie......

虽然看起来"优雅",但很多逻辑其实根本没必要封装成 Hook。

js 复制代码
// 没必要的 Hook
function useABC() {
  useEffect(() => {
    // 一些逻辑
  }, [])
}

// 更清晰的普通函数
function doABC() {
  // 同样的逻辑
}

滥用 Hooks 只会让代码更复杂、更难维护。


六、总结:Hooks 不是银弹 📌

Hooks 的确解决了 class 组件的一些痛点(比如逻辑复用),但它也带来了不少新的问题:

优点 ✅ 缺点 ❌
逻辑复用更方便(自定义 Hooks) 强依赖调用顺序,容易踩坑
代码更简洁(少了 class/this) useEffect/useCallback 设计复杂
更贴近函数式编程思想 滥用 Hooks → 代码更乱

所以,Hooks 不是完美解法,它只是一个工具。 真正优雅的代码,不是依赖"use"多少,而是 简单、可维护、可预期

也许未来 React 团队会给我们更直观的解决方案(比如 Signals),那时我们才可能真的告别这些"坑"。

相关推荐
JustHappy15 分钟前
我汇总了身边朋友的经历才发现,其实第一份实习是最难找的......
前端·后端·面试
星栈27 分钟前
Dioxus 的响应式系统:`Signal`、`Memo`、`Effect` 和异步状态到底该怎么分工
前端·前端框架
yingyima28 分钟前
Java 正则表达式:比你想象的更强大
前端
yuanyxh3 小时前
macOS 应用 - 纯对话生成
前端·macos·ai编程
大家的林语冰3 小时前
ES5 凉凉,Babel 8 正式发布,默认不再编译为 ES5 和 CJS......
前端·javascript·前端工程化
光影少年5 小时前
react批量更新、同步/异步更新场景
前端·react.js·掘金·金石计划
假如让我当三天老蒯5 小时前
模块化:ES Module 与 CommonJS 的区别
前端·面试
用户40950115773175 小时前
Private Forge v2.0 发布:12大前端业务场景技能系统
前端
weedsfly6 小时前
异步编程全景与事件循环——彻底搞懂 JS 执行机制
前端·javascript
用户059540174466 小时前
AI Agent记忆测试踩坑实录:Mock骗了我一周,Mem0+pytest一招破局
前端·css