React 组件传 children 的各种方案

自定义组件的时候往往需要传 children,由于写法比较多样,我就总结了一下。

方案列表

  • [1. 类组件](#1. 类组件)
    • [1.1 类组件,不使用解构](#1.1 类组件,不使用解构)
    • [1.2 类组件,使用解构](#1.2 类组件,使用解构)
  • [2. 函数组件](#2. 函数组件)
    • [2.1 函数组件,不使用解构](#2.1 函数组件,不使用解构)
    • [2.2 函数组件,外部解构](#2.2 函数组件,外部解构)
    • [2.3 函数组件,内部解构](#2.3 函数组件,内部解构)
  • [3. 普通函数](#3. 普通函数)
    • [3.1 普通函数,内部解构](#3.1 普通函数,内部解构)
    • [3.2 普通函数,外部解构](#3.2 普通函数,外部解构)
    • [3.3 普通函数,外部解构,不使用自定义Type](#3.3 普通函数,外部解构,不使用自定义Type)
    • [3.4 普通函数,不使用解构,不使用自定义Type](#3.4 普通函数,不使用解构,不使用自定义Type)
  • 调用及展示

要自定义的组件是这样的:

其中包含一个 title 和一个 children

定义一个后面要用到的 Props:

typescript 复制代码
/** 定义属性对象
 * - title: 标题
 * - children: 子组件
 */
type Props = {
  title: string;
  children?: React.ReactNode;
};

1. 类组件

1.1 类组件,不使用解构

typescript 复制代码
class ClassComponent1 extends Component<Props> {
  render(): ReactNode {
    return (
      <div style={{ backgroundColor: 'red' }}>
        <h2>{this.props.title}</h2>
        {this.props.children}
      </div>
    );
  }
}

1.2 类组件,使用解构

typescript 复制代码
class ClassComponent2 extends Component<Props> {
  render(): ReactNode {
    // 解构赋值
    const { title, children } = this.props;
    return (
      <div style={{ backgroundColor: 'red' }}>
        <h2>{title}</h2>
        {children}
      </div>
    );
  }
}

2. 函数组件

2.1 函数组件,不使用解构

typescript 复制代码
const FunctionComponent1: React.FC<Props> = (props) => {
  return (
    <div style={{ backgroundColor: 'orange' }}>
      <h2>{props.title}</h2>
      {props.children}
    </div>
  );
};

2.2 函数组件,外部解构

typescript 复制代码
const FunctionComponent2: React.FC<Props> = ({ title, children }) => {
  return (
    <div style={{ backgroundColor: 'orange' }}>
      <h2>{title}</h2>
      {children}
    </div>
  );
};

2.3 函数组件,内部解构

typescript 复制代码
const FunctionComponent3: React.FC<Props> = (props) => {
  // 解构赋值
  const { title, children } = props;
  return (
    <div style={{ backgroundColor: 'orange' }}>
      <h2>{title}</h2>
      {children}
    </div>
  );
};

3. 普通函数

3.1 普通函数,内部解构

typescript 复制代码
function NormalFunction1(props: Props) {
  // 解构赋值
  const { title, children } = props;
  return (
    <div style={{ backgroundColor: 'yellow' }}>
      <h2>{title}</h2>
      {children}
    </div>
  );
}

3.2 普通函数,外部解构

typescript 复制代码
function NormalFunction2({ title, children }: Props) {
  return (
    <div style={{ backgroundColor: 'yellow' }}>
      <h2>{title}</h2>
      {children}
    </div>
  );
}

3.3 普通函数,外部解构,不使用自定义Type

typescript 复制代码
function NormalFunction3({
  title,
  children,
}: {
  title: string;
  children?: React.ReactNode;
}) {
  return (
    <div style={{ backgroundColor: 'yellow' }}>
      <h2>{title}</h2>
      {children}
    </div>
  );
}

3.4 普通函数,不使用解构,不使用自定义Type

typescript 复制代码
function NormalFunction4(props: { title: string; children?: React.ReactNode }) {
  return (
    <div style={{ backgroundColor: 'yellow' }}>
      <h2>{props.title}</h2>
      {props.children}
    </div>
  );
}

调用及展示

typescript 复制代码
export default class ChildrenPage extends Component {
  render() {
    return (
      <div style={{ padding: '20px' }}>
        <h1>组件传children</h1>
        <ClassComponent1 title="类组件,不使用解构">
          <p>这里是children</p>
        </ClassComponent1>
        <ClassComponent2 title="类组件,使用解构">
          <p>这里是children</p>
        </ClassComponent2>
        <FunctionComponent1 title="函数组件,不使用解构">
          <p>这是里children</p>
        </FunctionComponent1>
        <FunctionComponent2 title="函数组件,外部解构">
          <p>这是里children</p>
        </FunctionComponent2>
        <FunctionComponent3 title="函数组件,内部解构">
          <p>这是里children</p>
        </FunctionComponent3>
        <NormalFunction1 title="普通函数,内部解构">
          <p>这里是children</p>
        </NormalFunction1>
        <NormalFunction2 title="普通函数,外部解构">
          <p>这里是children</p>
        </NormalFunction2>
        <NormalFunction3 title="普通函数,外部解构,不使用自定义Type">
          <p>这里是children</p>
        </NormalFunction3>
        <NormalFunction4 title="普通函数,不使用解构,不使用自定义Type">
          <p>这里是children</p>
        </NormalFunction4>
      </div>
    );
  }
}
相关推荐
婷婷婷婷几秒前
表格组件封装详解(含完整代码)
前端
晴虹2 分钟前
lecen:一个更好的开源可视化系统搭建项目--页面设计器(表单设计器)--全低代码|所见即所得|利用可视化设计器构建你的应用系统-做一个懂你的人
前端·后端·低代码
小皮虾6 分钟前
这应该是前端转后端最简单的办法了,不买服务器、不配 Nginx,也能写服务端接口,腾讯云云函数全栈实践
前端·javascript·全栈
码途进化论7 分钟前
Vue3 防重复点击指令 - clickOnce
前端·javascript·vue.js
神秘的猪头9 分钟前
🎣 拒绝面条代码!手把手带你用自定义 Hooks 重构 React 世界
javascript·react.js
小二·12 分钟前
从零手写俄罗斯方块(Tetris)——前端工程化实战与性能优化
前端·性能优化
xiaoxue..24 分钟前
高频事件的“冷静剂” 闭包的实用场景:防抖与节流
前端·javascript·面试·html·编程思想
优弧42 分钟前
2025 提效别再卷了:当我把 AI 当“团队”,工作真的顺了
前端
.try-1 小时前
cssTab卡片式
java·前端·javascript
怕浪猫1 小时前
2026最新React技术栈梳理,全栈必备
前端·javascript·面试