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>
    );
  }
}
相关推荐
繁依Fanyi8 分钟前
项目记录:「五秒反应挑战」小游戏的开发全过程
前端·codebuddy首席试玩官
肥肠可耐的西西公主29 分钟前
前端(vue)学习笔记(CLASS 6):路由进阶
前端·vue.js·学习
*小雪30 分钟前
uniapp打包H5,输入网址空白情况
前端·uni-app
李梨与狸1 小时前
vue中excel文件 打包后不展示问题
前端·vue.js·excel
前端达人1 小时前
React 播客专栏 Vol.13|样式不难搞,Tailwind CSS 与 SVG 实战入门
前端·javascript·css·react.js·前端框架
xcs194051 小时前
开发 前端搭建npm v11.4.0 is known not to run on Node.js v14.18.1.
前端·npm·node.js
等等5431 小时前
CSS高级技巧
前端·css
web_小码农2 小时前
前端实现流式输出《后端返回Markdown格式文本,前端输出类似于打字的那种》
前端
群联云防护小杜2 小时前
物联网僵尸网络防御:从设备认证到流量染色
运维·服务器·前端·网络·物联网·安全·ddos
YD12182 小时前
如何在 AWS 上构建支持 AVIF 的前端图片优化方案
前端·云计算·aws