REACT系列:1、React 中 render() 的目的

在 React 中,render() 方法是类组件的核心方法,它的主要目的是描述组件应该渲染什么内容到界面上

一、render() 的主要作用

1. 返回 JSX

render() 方法必须返回一个 React 元素,通常是 JSX:

scala 复制代码
class MyComponent extends React.Component {
  render() {
    return <h1>Hello, World!</h1>;
  }
}

2. 基于 state 和 props 动态渲染

render() 可以根据组件的状态和属性动态决定渲染内容:

scala 复制代码
class Counter extends React.Component {
  constructor(props) {
    super(props);
    this.state = { count: 0 };
  }

  render() {
    return (
      <div>
        <h2>Count: {this.state.count}</h2>
        <button onClick={() => this.setState({ count: this.state.count + 1 })}>
          Increment
        </button>
      </div>
    );
  }
}

3. 条件渲染

根据条件显示不同的 UI:

scala 复制代码
class UserGreeting extends React.Component {
  render() {
    const { isLoggedIn, username } = this.props;
    
    return (
      <div>
        {isLoggedIn ? (
          <h1>Welcome back, {username}!</h1>
        ) : (
          <h1>Please log in</h1>
        )}
      </div>
    );
  }
}

二、render() 的特点

1. 纯函数

render() 应该是纯函数:

  • 不修改组件状态
  • 不直接与浏览器交互
  • 相同的 props 和 state 总是返回相同的结果

2. 必需的方法

在类组件中,render() 是必须实现的方法(除了使用 React.PureComponent 的情况)。

3. 被 React 调用

开发者不直接调用 render(),React 在以下情况会自动调用:

  • 组件初始化时
  • state 更新时
  • props 更新时
  • 父组件重新渲染时

三、函数组件的对应概念

在函数组件中,没有明确的 render() 方法,整个函数就相当于 render()

scala 复制代码
// 函数组件 - 整个函数就是 render
function MyComponent(props) {
  return <h1>Hello, {props.name}!</h1>;
}

// 等同于类组件的 render()
class MyComponent extends React.Component {
  render() {
    return <h1>Hello, {this.props.name}!</h1>;
  }
}
相关推荐
FrontAI4 小时前
Next.js从入门到实战保姆级教程:环境配置与项目初始化
react.js·typescript·学习方法
用户3153247795456 小时前
React19项目中 FormEdit / FormEditModal 组件封装设计说明
前端·react.js
Ruihong8 小时前
Vue3 转 React:组件透传 Attributes 与 useAttrs 使用详解|VuReact 实战
vue.js·react.js
橘子编程10 小时前
React 19 全栈开发实战指南
前端·react.js·前端框架
弓.长.11 小时前
ReactNative for OpenHarmony项目鸿蒙化三方库:react-native-svg(CAPI) — 矢量图形组件
react native·react.js·harmonyos
局i12 小时前
从零搭建 Vite + React 项目:从环境准备到干净项目的完整指南
前端·react.js·前端框架
Lazy_zheng12 小时前
SDD 实战:用 Claude Code + OpenSpec,把 AI 编程变成“流水线”
前端·react.js·ai编程
光影少年12 小时前
如何实现RN应用的离线功能、数据缓存策略?
react native·react.js·掘金·金石计划
弓.长.14 小时前
ReactNative for OpenHarmony项目鸿蒙化三方库:rn-placeholder — 骨架屏占位组件
react native·react.js·harmonyos
whuhewei14 小时前
React性能优化
前端·react.js·性能优化