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

相关推荐
学嵌入式的小杨同学2 小时前
从零打造 Linux 终端 MP3 播放器!用 C 语言实现音乐自由
linux·c语言·开发语言·前端·vscode·ci/cd·vim
weixin_425543732 小时前
TRAE CN3.3.25 构建的Electron简易DEMO应用
前端·typescript·electron·vite·nestjs
Mr Xu_3 小时前
【Vue3 + ECharts 实战】正确使用 showLoading、resize 与 dispose 避免内存泄漏
前端·信息可视化·vue·echarts
0思必得03 小时前
[Web自动化] Selenium设置相关执行文件路径
前端·爬虫·python·selenium·自动化
雯0609~4 小时前
hiprint:实现项目部署与打印1-官网提供普通html版本
前端·html
不绝1914 小时前
UGUI——进阶篇
前端
Exquisite.4 小时前
企业高性能web服务器(4)
运维·服务器·前端·网络·mysql
2501_944525545 小时前
Flutter for OpenHarmony 个人理财管理App实战 - 账户详情页面
android·java·开发语言·前端·javascript·flutter
2601_949857435 小时前
Flutter for OpenHarmony Web开发助手App实战:快捷键参考
前端·flutter
wangdaoyin20105 小时前
若依vue2前后端分离集成flowable
开发语言·前端·javascript