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>;
  }
}
相关推荐
AAA阿giao12 小时前
从零拆解一个 React + TypeScript 的 TodoList:模块化、数据流与工程实践
前端·react.js·ui·typescript·前端框架
摘星编程1 天前
React Native鸿蒙版:Image图片占位符
react native·react.js·harmonyos
飞羽殇情1 天前
基于React Native鸿蒙跨平台开发构建完整电商预售系统数据模型,完成参与预售、支付尾款、商品信息展示等
react native·react.js·华为·harmonyos
摘星编程1 天前
React Native + OpenHarmony:ImageSVG图片渲染
javascript·react native·react.js
摘星编程1 天前
OpenHarmony + RN:Text文本书写模式
javascript·react native·react.js
xixixin_1 天前
【React】中 Body 类限定法:优雅覆盖挂载到 body 的组件样式
前端·javascript·react.js
摘星编程1 天前
用React Native开发OpenHarmony应用:Image网络图片加载
javascript·react native·react.js
摘星编程1 天前
OpenHarmony环境下React Native:ImageBase64图片显示
javascript·react native·react.js
摘星编程1 天前
React Native鸿蒙:Image本地图片显示
javascript·react native·react.js
2501_921930832 天前
基础入门 React Native 鸿蒙跨平台开发:Video 全屏播放与画中画 鸿蒙实战
react native·react.js·harmonyos