news 2026/4/16 19:25:32

React 避坑指南:让电脑卡死的“无限循环“

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
React 避坑指南:让电脑卡死的“无限循环“

写在前面:如果开发的时候突然听到电脑风扇狂转,或者浏览器卡死不动了,别慌,先按电源键强制关机(bushi)。

广告植入:欢迎访问我的个人网站:https://hixiaohezi.com


作为一个拥有 x 年经验的老菜鸟,我大多时候用的的 vue , 最近在学 react ,觉得useEffect是个好东西。直到我写了一个看似人畜无害的数据查询功能。

需求很简单:当筛选条件变化时,重新请求数据。

function userList() { const [data, setData] = useState([]); // 筛选条件:查"激活状态"的用户 const filter = { status: 'active' }; useEffect(() => { console.log('发起请求...'); fetchData(filter).then(res => setData(res)); }, [filter]); // 依赖 filter,没毛病吧? return <div>用户列表...</div>; }

保存,刷新。

问题出现

刚开始页面还挺正常。但过了一会儿笔记本的风扇声音突然变大,电脑页整个卡住了。

打开控制台(趁着还能动),Network 面板里那是红旗招展,请求像机关枪一样突突突地发出去:

Request 1 Request 2 ... Request 10086

我不得不使出绝招: 杀掉浏览器进程。

查找原因:该死的"引用类型"

菜,无需多言。

在 JavaScript 里,{}永远不等于{}

来看看发生了什么惨案:

  1. 组件挂载,创建filter对象(地址 A)。
  2. useEffect执行,发现filter是新的,发起请求
  3. 请求回来,调用setData更新数据。
  4. 组件重新渲染(重点来了!)。
  5. 组件函数重新执行,创建新的filter对象(地址 B)。
  6. useEffect再次对比依赖:地址 A !== 地址 B
  7. 又要执行 Effect!
  8. 回到第 2 步,无限套娃…

解决方案

找到原因,解决办法也就有了。

方案一:useMemo 大法 (推荐 ✅)

既然是对象变了,那我就让它别变。用useMemo把它"冻"住:

// 只有依赖项变了,filter 才会变 const filter = useMemo(() => ({ status: 'active' }), []); useEffect(() => { fetchData(filter); }, [filter]);

方案二:简单粗暴拆解法 (最实用 ✅)

别传对象了,能不能直接传基本类型?

const status = 'active'; useEffect(() => { fetchData({ status }); // 在里面组装对象 }, [status]); // 依赖字符串,字符串 'active' === 'active',稳如老狗

方案三:JSON.stringify (野路子 ⚡)

实在懒得拆,就把对象转成字符串对比。虽然有点 low,有时候还挺好使。

const filter = { status: 'active' }; useEffect(() => { fetchData(filter); }, [JSON.stringify(filter)]); // 只要内容不变,字符串就不变

总结

重启完电脑,看着不再狂转的风扇,我悟了:
React 的依赖比较是"浅比较",它只看皮囊(内存地址),不看灵魂(对象内容)。

作为一个老菜鸟,不仅要防闭包,还得防对象。这哪里是写代码,简直是在玩扫雷。


如果这个坑你也踩过,握个爪。

最后,再加个广告,欢迎访问我的个人网站:

👉 hixiaohezi.com

(这里是我的个人网站,虽然没多少技术含量,但主打一个真实)

祝大家的代码永远不卡顿,CPU 永远冷静!

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 12:16:25

music-api:快速上手的跨平台音乐解析完整教程

还在为不同音乐平台的API接入而烦恼吗&#xff1f;music-api项目为你提供了一站式解决方案&#xff0c;让你轻松获取四大主流音乐平台的歌曲播放地址。无论是开发音乐播放器、构建推荐系统&#xff0c;还是创建个人音乐网站&#xff0c;这个开源工具都能显著提升你的开发效率。…

作者头像 李华
网站建设 2026/4/16 12:13:21

科技赋能文化养老,红松小课开启退休生活品质新时代

在数字中国建设全面推进的今天&#xff0c;科技应用正在为各个年龄群体创造更加便捷、丰富的生活方式。对于规模日益庞大的退休群体而言&#xff0c;科技不仅是工具&#xff0c;更是连接社会、实现自我价值的重要桥梁。专注于服务退休人群的红松小课&#xff0c;正是通过技术创…

作者头像 李华
网站建设 2026/4/16 12:15:09

在asp.net web应用程序,老是访问同一个Handler1.ashx

前言项目是在vs2022下开发&#xff0c;在一般处理程序有二个文件moveToUp.ashx和moveToTop.ashx。在模拟和项目中请求访问时老是指向moveToTop.ashx。上下项目全部度找问题&#xff0c;清仓项目&#xff0c;重新生成&#xff0c;删除bin和obj目录下所有文件&#xff0c;还是这指…

作者头像 李华
网站建设 2026/4/16 4:20:24

机械故障诊断完整指南:基于振动信号分析的实战教程

机械故障诊断完整指南&#xff1a;基于振动信号分析的实战教程 【免费下载链接】机械故障诊断与振动信号数据集 本仓库提供了一个振动信号数据集&#xff0c;旨在帮助工程师和科学家对机械设备的振动信号进行分析和处理。该数据集包含了多个振动信号示例&#xff0c;适用于故障…

作者头像 李华
网站建设 2026/4/16 6:00:17

TIOBE 编程社区 查看各种编程语言流行程度和趋势的社区

TIOBE 编程社区&#xff1a;查看编程语言流行程度和趋势的权威平台 TIOBE 编程社区指数&#xff08;TIOBE Programming Community Index&#xff09;是一个全球知名的编程语言流行度指标&#xff0c;由荷兰软件公司 TIOBE 维护。它通过分析搜索引擎&#xff08;如 Google、Bin…

作者头像 李华
网站建设 2026/4/16 5:58:26

基于Vue框架的宠物医院系统设计与实现

青岛恒星科技学院 毕业论文&#xff08;设计&#xff09;开题报告 题 目&#xff1a; 基于Vue框架的宠物医院系统 设计与实现 学 院 信息工程学院 专 业 软件工程 校 号 2102772 学 生 高爱鹏…

作者头像 李华