react + Typescript 中 react有多少内置的类型 分别是什么

news/2024/7/15 17:56:33 标签: react.js, typescript, 前端

react + Typescript 中 react有多少内置的类型 分别是什么

React 和 TypeScript 结合使用时,React 提供了一系列的内置类型(也称为类型定义或类型别名)来帮助你在 TypeScript 中编写类型安全的代码。这些类型定义涵盖了 React 的各个方面,从组件类和函数组件到组件属性(props)、状态(state)和事件处理等。

以下是一些常用的 React 内置类型:

  1. ReactNode: 用于描述可以被渲染的内容,比如 JSX 表达式、字符串、数字、或者是这些类型的数组等。

  2. ReactElement: 通常由 JSX 表达式返回的类型,代表了虚拟 DOM 元素。

  3. ReactComponentElement: 特定于类组件或函数组件的元素。

  4. ReactFragment: 用于描述一组可以被渲染的子元素,不需要额外的父节点。

  5. ReactPortal: 用于将子节点渲染到不同 DOM 子树的类型。

  6. RefObject: 用于描述通过 React.createRef 创建的 ref 对象。

  7. MutableRefObject: 用于描述通过 useRef 创建的可变 ref 对象。

  8. ReactElement: 代表 React 元素,是由 React.createElement() 返回的类型。

  9. ComponentType<P>: 用于描述一个接受泛型参数 P 的类组件或函数组件。

  10. FunctionComponent<P>FC<P>: 用于描述一个接受泛型参数 P 的函数组件。

  11. ClassComponent<P, S>: 用于描述一个接受泛型参数 PS 的类组件。

  12. ReactChild | ReactChildren: 用于描述可以作为子元素的类型。

  13. ReactEventHandler: 用于描述事件处理函数的类型。

  14. SyntheticEvent: 用于描述 React 封装的合成事件对象。

  15. ChangeEvent, MouseEvent, KeyboardEvent 等: 表示特定类型的合成事件。

  16. PropsWithChildren<P>: 用于描述一个组件的属性 P,并且这个组件可以有子元素。

  17. PropsWithRef<P>: 用于描述一个组件的属性 P,并且这个组件可以接受 ref。

  18. Context<T>: 用于描述 React 上下文对象的类型。

  19. Provider<T>Consumer<T>: 用于描述 React 上下文的提供者和消费者组件。

  20. ReactLazy: 用于描述通过 React.lazy 创建的懒加载组件。

  21. ReactMemo: 用于描述通过 React.memo 创建的记忆化组件。

这些类型定义是通过 React 的 TypeScript 类型定义文件(通常是 @types/react 包)提供的,是开发 TypeScript 项目时使用 React 的基础。随着 React 的版本更新,可能会引入新的类型或弃用旧的类型,因此建议查看具体版本的类型定义文件或官方文档以获取最新的信息。


http://www.niftyadmin.cn/n/5390232.html

相关文章

【数据结构】每天五分钟,快速入门数据结构(二)——链表

目录 一 构建一个单向链表 二 特点 三 时间复杂度 四 相关算法 1.判断链表是否成环及成环位置 2.链表反转 五 Java中的LinkedList 类 1.使用 2.LinkedList 方法 一 构建一个单向链表 // 设计链表结构class ListNode {int val;ListNode next;ListNode(){}ListNode(int…

邓俊辉 c++数据结构第二章 向量

数据结构是计算机存储、组织数据的方式,是指相互之间存在一种或多种特定关系的数据元素的集合。数据结构分为&#xff1a;线性结构、线性结构和非线性结构。 线性结构根据逻辑次序和物理次序的关系&#xff0c;分为向量和列表。向量的逻辑次序和物理位置是对应的&#xff1b;列…

【高频SQL题目】再做一遍 1164.指定日期的产品价格

题目要求&#xff1a; 产品数据表: Products ------------------------ | Column Name | Type | ------------------------ | product_id | int | | new_price | int | | change_date | date | ------------------------ (product_id, change_date)…

飞天使-linux操作的一些技巧与知识点7-devops

文章目录 简述devopsCICD 简述devops 让技术团队&#xff0c;运维&#xff0c;测试等团队实现一体式流程自动化 进阶版图 CICD 持续集成&#xff0c; 从编译&#xff0c;测试&#xff0c;发布的完成自动化流程 持续交付&#xff0c;包含持续集成&#xff0c;并且将项目部署…

基于springboot+vue的安康旅游网站(前后端分离)

博主主页&#xff1a;猫头鹰源码 博主简介&#xff1a;Java领域优质创作者、CSDN博客专家、阿里云专家博主、公司架构师、全网粉丝5万、专注Java技术领域和毕业设计项目实战&#xff0c;欢迎高校老师\讲师\同行交流合作 ​主要内容&#xff1a;毕业设计(Javaweb项目|小程序|Pyt…

国家建筑装配式内装产业基地在沪成立,副主任单位优积科技协同助推绿色低碳循环发展

上海市室内装饰行业协会装配式内装产业专业委员会成立大会暨“国家建筑装配式内装产业基地”项目启动会于3月21日下午1点在上海光大酒店隆重举行。出席此次活动的包括市装协会长徐国俭&#xff0c;市装协党支部书记兼秘书长丛国梁&#xff0c;市装协装配式内装委主任顾泰昌&…

Spring Boot面试题解析

1. 什么是 Spring Boot&#xff1f;【重点】 多年来&#xff0c;随着新功能的增加&#xff0c;Spring变得越来越复杂&#xff1b;一个Spring项目&#xff0c;我们必须做添加构建路径或添加Maven依赖关系&#xff0c;配置应用程序服务器&#xff0c;添加Spring配置等工作&#…

robots.txt 文件规则

robots.txt 是一种用于网站根目录的文本文件&#xff0c;其主要目的在于指示网络爬虫&#xff08;web crawlers&#xff09;和其他网页机器人&#xff08;bots&#xff09;哪些页面可以抓取&#xff0c;以及哪些页面不应该被抓取。可以看作是网站和搜索引擎机器人之间的一个协议…