0

0

React 组件重新渲染机制详解:为何 Child 组件会重复渲染?

DDD

DDD

发布时间:2025-10-06 11:45:11

|

394人浏览过

|

来源于php中文网

原创

react 组件重新渲染机制详解:为何 child 组件会重复渲染?

本文旨在解释在 React 应用中,即使子组件的 props 没有发生变化,仍然可能发生重新渲染的现象。我们将通过一个简单的示例,深入分析 React 的渲染机制,并提供解决方案,避免不必要的渲染,优化应用性能。核心在于理解组件创建的时机以及props传递的方式。

React 组件重新渲染的原因分析

在 React 中,组件的重新渲染并非完全由 props 的变化驱动。即使 props 看起来没有改变,组件仍然可能因为父组件的重新渲染而被触发重新渲染。理解这一点对于优化 React 应用的性能至关重要。

考虑以下代码:

import { useState, useEffect } from 'react';

const App = () => {
  const [now, setNow] = useState()

  // Start a timer
  useEffect(() => {
    const interval = setInterval(() =>
      setNow(Date.now()), 100)
    return () => clearInterval(interval)
  }, [])

  return (
    
) } export default App const Parent = ({ children }) => { return (
{children}
) } const Child = () => { console.log('rendered') return (

whatever

) }

在这个例子中,App 组件每 100 毫秒更新一次状态 now,导致 App 组件自身重新渲染。由于 Child 组件是作为 JSX 直接写在 Parent 组件的 children 中,每次 App 组件重新渲染时,都会创建一个新的 Child 组件实例。尽管 Child 组件的 props 并没有发生变化,但 React 仍然会将其视为一个新的组件,并触发重新渲染。 这就是为什么在控制台中会看到 rendered 不断输出的原因。

解决方案:提升状态管理

要解决这个问题,我们需要避免每次父组件渲染时都重新创建子组件。一种常见的解决方案是将状态提升到 Parent 组件中,这样 Child 组件只会在 App 组件初始化时创建一次,并作为 children prop 传递给 Parent 组件。

法语写作助手
法语写作助手

法语助手旗下的AI智能写作平台,支持语法、拼写自动纠错,一键改写、润色你的法语作文。

下载

修改后的代码如下:

import { useEffect, useState } from 'react';

const Child = () => {
  console.log('rendered')
  return (
    

whatever

) } const Parent = ({ children }) => { const [now, setNow] = useState() // Start a timer useEffect(() => { const interval = setInterval(() => setNow(Date.now()), 100) return () => clearInterval(interval) }, []) return (
{children}
) } const App = () => { return (
) } export default App;

在这个修改后的版本中,状态 now 被移动到了 Parent 组件中。App 组件只负责渲染 Parent 组件,并将 Child 组件作为 children 传递。由于 Child 组件只在 App 组件初始化时创建一次,因此即使 Parent 组件因为状态更新而重新渲染,Child 组件也不会重新渲染,除非它的 props 发生变化。

其他优化策略

除了提升状态之外,还可以使用以下策略来优化 React 组件的渲染:

  • React.memo: 使用 React.memo 可以缓存组件的渲染结果,只有当 props 发生变化时才会重新渲染。
  • useMemo 和 useCallback: 使用 useMemo 和 useCallback 可以缓存计算结果和函数,避免在每次渲染时都重新计算或创建函数。
  • 避免不必要的状态更新: 尽量避免频繁的状态更新,可以使用 debounce 或 throttle 来限制状态更新的频率。

总结

理解 React 组件的重新渲染机制对于编写高性能的 React 应用至关重要。通过避免不必要的渲染,我们可以显著提高应用的性能和响应速度。在实际开发中,需要根据具体情况选择合适的优化策略,以达到最佳的性能效果。 记住,组件创建的时机和 props 传递的方式是影响渲染的关键因素。

相关专题

更多
PPT动态图表制作教程大全
PPT动态图表制作教程大全

本专题整合了PPT动态图表制作相关教程,阅读专题下面的文章了解更多详细内容。

13

2026.01.07

c++ Libcurl用法详解
c++ Libcurl用法详解

本专题整合了c++ Libcurl用法详解,阅读专题下面的文章了解更多详细内容。

0

2026.01.07

c++ Libcurl用法大全
c++ Libcurl用法大全

本专题整合了c++ Libcurl用法详解,阅读专题下面的文章了解更多详细内容。

0

2026.01.07

C++ vector用法汇总
C++ vector用法汇总

本专题整合了C++中vector的用法大全,阅读专题下面的文章了解更多详细内容。

2

2026.01.07

C++ vector用法大全
C++ vector用法大全

本专题整合了C++中vector的用法大全,阅读专题下面的文章了解更多详细内容。

0

2026.01.07

2026年漫蛙最新官网地址
2026年漫蛙最新官网地址

漫蛙官网访问入口为https://manwa.me,另提供manwa.cc、manwa.vip、manwa.site等多节点备用链接,支持跨设备同步、个性化阅读及HTTPS安全加密。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

60

2026.01.07

php做exe需要在什么样的环境
php做exe需要在什么样的环境

PHP无法真正编译为EXE,所谓打包实为将解释器、脚本及依赖库封装成自解压容器;主流方案是ExeOutputforPHP(商业、Windows)和PHPDesktop(开源、跨平台),需手动处理扩展依赖、路径适配与运行时限制。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1

2026.01.07

抖音抖币官方充值渠道汇总
抖音抖币官方充值渠道汇总

抖音官方抖币充值官网入口为https://pay.douyin.com/,具备直连支付系统、全端统一鉴权、HTTPS加密传输、多设备实时同步等特性,支持微信/支付宝/银联/话费等多种支付方式及严密账户安全机制。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

5

2026.01.07

vscode创建html的教程
vscode创建html的教程

在 Visual Studio Code 中创建 HTML 文件的步骤如下:打开 VSCode并创建新文件。选择 "HTML" 模板。输入 HTML 代码。保存文件。(可选)预览文件。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

3

2026.01.07

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 3.4万人学习

国外Web开发全栈课程全集
国外Web开发全栈课程全集

共12课时 | 0.9万人学习

React核心原理新老生命周期精讲
React核心原理新老生命周期精讲

共12课时 | 1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号