react 中 FC 模块作用

devtools/2024/11/14 1:20:49/

`React.FC` 是一个泛型类型,用于定义函数组件的类型

一、类型定义和代码可读性

1. 明确组件类型

使用`React.FC`定义一个组件时,使得组件的输入(props)和输出(返回的 React 元素)都有明确的类型定义。

import React from "react";interface Props {name: string;}const MyComponent: React.FC<Props> = ({ name }) => {return <div>Hello, {name}!</div>;};

2. 增强代码可读性

看到`React.FC`就表明这是一个 React 函数组件。同时可以查看组件 Props 的类型。

二、隐式的属性类型和默认值

1. 隐式的属性类型检查

使用`React.FC`后,TypeScript 会自动将`children`的类型设置为`ReactNode`。

import React from "react";const MyComponent: React.FC = ({ children }) => {return <div>{children}</div>;};// 正确的用法,因为 `React.FC` 自动处理了 `children` 类型<MyComponent>Hello World</MyComponent>;// 错误的用法,因为 `number` 类型的子元素不符合 `ReactNode` 类型(除了特定情况)<MyComponent>{123}</MyComponent>;

2. 默认属性值支持

`React.FC`还支持为组件的属性设置默认值。在组件定义中,可以通 `defaultProps`属性来设置默认值。

import React from "react";interface Props {count: number;}const MyComponent: React.FC<Props> = ({ count }) => {return <div>{count}</div>;};MyComponent.defaultProps = { count: 0 };// 可以不传 `count` 属性,此时 `count` 的值为默认值 `0`<MyComponent />;


http://www.ppmy.cn/devtools/133791.html

相关文章

【Spring】@Autowired与@Resource的区别

Autowired 和 Resource 是 Spring 框架中用于依赖注入的两种注解。虽然它们的主要目的相同&#xff0c;即实现自动装配&#xff0c;但它们有一些关键的区别。 Autowired 来源&#xff1a;Spring 框架本身。默认按类型装配&#xff1a;如果没有指定 required 属性&#xff0c;并…

kaggle 如何利用API下载数据集

首先 上传kaggle官网生成得 API 密钥&#xff1a; kaggle.json 文件。放到该代码同目录下&#xff0c;再运行一下代码。 注&#xff1a; 只需要修改下载竞赛数据集&#xff0c;就可以选择你的指定数据集。 jupyter文件运行 #首先 上传 kaggle.json 文件并设置 API 密钥 #再…

Py2Neo 库将 Json 文件导入 Neo4J

在Python中&#xff0c;利用Py2Neo库可以将JSON数据导入Neo4j图数据库&#xff0c;从而构建知识图谱。Py2Neo是一个Python库&#xff0c;用于与Neo4j图数据库交互。以下是如何使用Py2Neo从JSON文件导入数据的详细步骤&#xff1a; 1. 安装所需库 确保已经安装py2neo库。如果没…

golang 泛型 middleware 设计模式: 一次只做一件事

golang 泛型 middleware 设计模式: 一次只做一件事 1. 前言 本文主要介绍 在使用 gRPC 和 Gin 框架中常用的 middleware 设计模式 还有几种叫法 装饰器模式Pipeline 模式 设计思想: 10 个 10 行函数, 而不是 1 个 100 行函数一次只做一件事, 而不一次做多件事单一职责 2…

基于Java+SpringBoot在线考试系统

一、作品包含 源码数据库设计文档全套环境和工具资源部署教程 二、项目技术 前端技术&#xff1a;Html、Css、Js、Vue、Element-ui 数据库&#xff1a;MySQL 后端技术&#xff1a;Java、Spring Boot、MyBatis 三、运行环境 开发工具&#xff1a;IDEA/eclipse 数据库&…

Spring Task详细讲解

✨Spring Task简介 Spring Task 是 Spring 提供的轻量级定时任务工具&#xff0c;也就意味着不需要再添加第三方依赖了&#xff0c;相比其他第三方类库更加方便易用。可以按照约定的时间自动执行某个代码逻辑。 使用场景&#xff1a; 信用卡每月还款提醒银行贷款每月还款提醒…

vue3使用element-plus,树组件el-tree增加引导线

vue3使用element-plus&#xff0c;树组件el-tree增加引导线 vue3项目element-plus&#xff0c;树组件el-tree增加引导线 element-plus组件库的el-tree样式 因为element的样式不满足当前的的需求&#xff0c;UI图&#xff0c;所以对el-tree进行增加了引导线 修改样式如下&am…

Vagrant 没了 VirtualBox 的话可以配 Qemu

开源虚拟机软件 VirtualBox 从当初不可一世的 Sun 易手到 Oracle 之间&#xff0c;变得不那么被许多公司信任了。之前一直是用 Vagrant 搭配 VirtualBox 在 Mac 下使用 Linux 虚拟机&#xff0c;因为不需要用到 Linux 桌面&#xff0c;用 Vagrant 操作虚拟机非常方便。但现在不…