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

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 的版本更新,可能会引入新的类型或弃用旧的类型,因此建议查看具体版本的类型定义文件或官方文档以获取最新的信息。

相关推荐
小小小小宇7 小时前
虚拟列表兼容老DOM操作
前端
悦悦子a啊7 小时前
Python之--基本知识
开发语言·前端·python
安全系统学习7 小时前
系统安全之大模型案例分析
前端·安全·web安全·网络安全·xss
涛哥码咖8 小时前
chrome安装AXURE插件后无效
前端·chrome·axure
OEC小胖胖8 小时前
告别 undefined is not a function:TypeScript 前端开发优势与实践指南
前端·javascript·typescript·web
行云&流水8 小时前
Vue3 Lifecycle Hooks
前端·javascript·vue.js
Sally璐璐8 小时前
零基础学HTML和CSS:网页设计入门
前端·css
老虎06279 小时前
JavaWeb(苍穹外卖)--学习笔记04(前端:HTML,CSS,JavaScript)
前端·javascript·css·笔记·学习·html
三水气象台9 小时前
用户中心Vue3网页开发(1.0版)
javascript·css·vue.js·typescript·前端框架·html·anti-design-vue
灿灿121389 小时前
CSS 文字浮雕效果:巧用 text-shadow 实现 3D 立体文字
前端·css