news 2026/5/15 23:21:29

如何解决React中props未更新的问题

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
如何解决React中props未更新的问题

如何解决React中props未更新的问题


正文目录

  1. props更新机制速览(30秒版)
  2. 7大「不更新」常见原因&现场代码
  3. DevTools定位三步法
  4. 性能对比&最佳实践
  5. 一句话总结

一、props更新机制速览(30秒版)

  1. 父组件setState→ 子组件re-render(默认)
  2. props引用变化→ 触发子组件更新
  3. 被memo/shouldComponentUpdate跳过→ 不更新(性能优化)

不更新 = 触发器没触发 or 被跳过。


二、7大「不更新」常见原因&现场代码

原因现场代码修复
① 父组件未setState父没setState()正确触发setState
② 直接改对象/数组list.push(item)setList([...list,item])
③ 被memo跳过React.memo+新引用稳定引用 or 去掉memo
④ 深对象未Immerobj.a.b=ximmer或展开赋值
⑤ 被shouldComponentUpdate跳过未实现SCU实现SCU or 去掉SCU
⑥ 组件卸载后setState异步回调里setStateAbortController取消
⑦ 条件渲染undefinedif(x)return<A/>无elsereturn x?<A/>:null

三、DevTools定位三步法

  1. Profiler录制:React DevTools→Profiler→录制操作。
  2. Why did this render?:点击红点→查看「未更新」原因。
  3. 对比prev/next props:确认「旧值=新值」→被跳过。

四、性能对比&最佳实践

策略渲染次数帧率现象
直接改对象200+15fps白屏
正确setState560fps精准更新

最佳实践

  • 用「Immer」深更新:setUser(produce(draft=>{draft.name='Tom'}))
  • 用「AbortController」取消异步:controller.abort()
  • 用「可选链」兜底:data?.list??[]

五、一句话总结

「props不更新」= 父没setState or 被跳过。」
用「正确setState+Immer+AbortController」三件套,让每一次props都精准更新,永远零白屏!


最后问候亲爱的朋友们,并邀请你们阅读我的全新著作

📚 《 React开发实践:掌握Redux与Hooks应用 》

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

告别截图!Antigravity 集成 Figma MCP 打造像素级还原的 AI 编程体验

🚀 告别截图!Antigravity 集成 Figma MCP 打造像素级还原的 AI 编程体验 作为开发者,你是不是经常截图发给 AI 让它写 CSS,结果写出来的效果总是“差强人意”?👀 间距不对、颜色有色差、字体搞错…… 今天我们要玩点高端的!利用 MCP (Model Context Protocol) 协议,…

作者头像 李华
网站建设 2026/5/12 16:43:10

实测对比后!千笔,最受欢迎的AI论文写作软件

你是否曾为论文选题发愁&#xff1f;是否在深夜面对空白文档无从下笔&#xff1f;是否反复修改却总觉得表达不够专业&#xff1f;论文写作不仅是对知识的考验&#xff0c;更是对耐心和效率的挑战。对于无数本科生来说&#xff0c;从开题到定稿&#xff0c;每一步都充满压力。而…

作者头像 李华
网站建设 2026/5/12 17:46:07

MySQL之InnoDB单表推荐2000W记录缘由

MySQL之InnoDB单表推荐2000W记录缘由 一、概述 在MySQL数据库设计实践中&#xff0c;业界普遍推荐InnoDB单表记录数控制在2000万&#xff08;20M&#xff09;左右。这个数值并非MySQL的硬性限制&#xff0c;而是基于性能、维护成本和架构设计等多个维度综合考量的经验值。本文将…

作者头像 李华
网站建设 2026/5/12 17:46:10

lvgl v8之label使用示例

void lvgl_test() {lv_obj_t* label1 = lv_label_create(lv_scr_act());

作者头像 李华
网站建设 2026/5/12 17:46:10

导师严选! AI论文软件 千笔ai写作 VS 文途AI,继续教育写作者必备!

随着人工智能技术的迅猛迭代与普及&#xff0c;AI辅助写作工具已逐步渗透到高校学术写作场景中&#xff0c;成为专科生、本科生、研究生完成毕业论文不可或缺的辅助手段。越来越多面临毕业论文压力的学生&#xff0c;开始依赖各类AI工具简化写作流程、提升创作效率。但与此同时…

作者头像 李华