HOW - React 组件中传递一个组件属性如何定义

在 React 中,如果你希望通过属性传递一个组件,通常有以下几种常见情况及对应的类型定义方法。


1. 传递一个 React 组件类型

如果你希望传递的是一个组件(例如 MyComponent 或类似的组件),可以用 React.ComponentType 定义类型。

tsx 复制代码
interface Props {
    Component: React.ComponentType<any>; // 接受任何组件
}

const Wrapper: React.FC<Props> = ({ Component }) => {
    return (
        <div>
            <Component />
        </div>
    );
};

// 用法
const MyComponent = () => <div>Hello</div>;

<Wrapper Component={MyComponent} />;
类型解释
  • React.ComponentType<any>: 表示一个可以渲染的 React 组件,可能是函数组件或类组件。
  • 如果你知道具体的组件需要的 props 类型,可以替换 any 为具体的 props 类型。

2. 传递一个 React 节点或组件实例

如果允许传递组件实例(例如 <MyComponent />)或普通的 React 节点,类型是 React.ReactNode

tsx 复制代码
interface Props {
    children: React.ReactNode; // React 节点或组件实例
}

const Wrapper: React.FC<Props> = ({ children }) => {
    return <div>{children}</div>;
};

// 用法
<Wrapper>
    <div>Hello</div>
    <MyComponent />
</Wrapper>;
类型解释
  • React.ReactNode 表示任何可以被渲染的内容,包括:
    • JSX 元素
    • 字符串、数字、布尔值、nullundefined
    • 数组
    • React.Fragment

3. 传递一个渲染函数

如果你希望传递的是一个渲染函数(可以接收参数并返回一个组件),可以用 (props: Props) => JSX.Element 定义类型。

tsx 复制代码
interface Props {
    render: (data: string) => JSX.Element;
}

const Wrapper: React.FC<Props> = ({ render }) => {
    const data = "Hello, world!";
    return <div>{render(data)}</div>;
};

// 用法
<Wrapper render={(data) => <div>{data}</div>} />;
类型解释
  • (data: string) => JSX.Element 是一个函数类型,接受 data 参数并返回 JSX。

4. 动态组件(带 props 的组件)

如果传递的组件需要特定的 props,可以明确指定类型。

tsx 复制代码
interface ChildProps {
    message: string;
}

interface WrapperProps {
    Component: React.ComponentType<ChildProps>; // 组件需要 ChildProps 类型的 props
}

const Wrapper: React.FC<WrapperProps> = ({ Component }) => {
    return <Component message="Hello from Wrapper" />;
};

// 用法
const MyComponent: React.FC<ChildProps> = ({ message }) => <div>{message}</div>;

<Wrapper Component={MyComponent} />;

选择适合的类型

用途 类型定义
传递 React 组件类型 React.ComponentType
传递组件实例或子节点 React.ReactNode
传递渲染函数 (props: Props) => JSX.Element
传递带特定 props 的组件类型 React.ComponentType<Props>

根据实际需求选择合适的类型!

相关推荐
10年前端老司机5 分钟前
React 受控组件和非受控组件区别和使用场景
前端·javascript·react.js
夏晚星6 分钟前
vue实现微信聊天emoji表情
前端·javascript
停止重构8 分钟前
【方案】前端UI布局的绝技,响应式布局,多端适配
前端·网页布局·响应式布局·grid布局·网页适配多端
極光未晚8 分钟前
TypeScript在前端项目中的那些事儿:不止于类型的守护者
前端·javascript·typescript
ze_juejin9 分钟前
Vue3 + Vite + Ant Design Vue + Axios + Pinia 脚手架搭建
前端·vue.js
Rrvive10 分钟前
原型与原型链到底是什么?
javascript
lichenyang45311 分钟前
React项目(移动app)
前端
用户618482402195112 分钟前
Vue-library-start,一个基于Vite的vue组件库开发模板
前端
美团技术团队23 分钟前
报名 | 美团技术沙龙第86期:多业务场景下,美团如何做性能优化
前端
安替-AnTi1 小时前
基于 React 和 TypeScript 搭建的机器学米其林餐厅数据分析项目
react.js·typescript·数据分析·毕设·米其林