当前位置: 首页 > article >正文

React 泛型组件:用TS来打造灵活的组件。

文章目录

  • 前言
    • 一、什么是泛型组件?
    • 二、为什么需要泛型组件?
    • 三、如何在 React 中定义泛型组件?
      • 基础泛型组件示例
      • 使用泛型组件
    • 四、泛型组件的高级用法
      • 带默认类型的泛型组件
      • 多个泛型参数
    • 五、泛型组件的实际应用场景
      • 数据展示组件
      • 表单组件
      • 状态管理
    • 注意事项
  • 总结


前言

在 React 开发中,我们常常需要创建可复用的组件。然而,随着项目规模的扩大,组件需要处理的类型也变得多样化。为了在保持组件灵活性的同时确保类型安全,React 结合 TypeScript 的泛型组件成为了一种强大的解决方案。本文将深入探讨 React 泛型组件的概念、用法及其在实际项目中的应用。

一、什么是泛型组件?

泛型组件是一种可以在定义时使用类型参数(泛型)的组件。类型参数允许组件在不同的上下文中处理不同的数据类型,而无需为每种类型编写单独的组件。泛型组件通过类型参数提供了灵活性、类型安全和可重用性。

二、为什么需要泛型组件?

  1. 灵活性:一个组件可以处理多种类型的数据,而无需重复代码。
  2. 类型安全:通过泛型,TypeScript 可以在编译时检查类型是否正确。
  3. 可重用性:减少重复代码,提高组件的复用性。

三、如何在 React 中定义泛型组件?

基础泛型组件示例

假设你有一个组件,用于显示列表数据,但列表项的类型可能是任意的(例如,字符串、对象等)。你可以使用泛型来定义这个组件:

	import React from 'react';interface ListProps<T> {items: T[];renderItem: (item: T) => React.ReactNode;}function List<T>({ items, renderItem }: ListProps<T>) {return (<ul>{items.map((item, index) => (<li key={index}>{renderItem(item)}</li>))}</ul>);}
  • T 是一个类型参数,表示列表项的类型。
  • items 是一个泛型数组 T[]
  • renderItem 是一个函数,接收一个 T 类型的参数,并返回一个 React 节点。

使用泛型组件

假设你有一个 User 类型,你想用 List 组件显示用户列表:

	interface User {id: number;name: string;}const users: User[] = [{ id: 1, name: 'Alice' },{ id: 2, name: 'Bob' },];function App() {return (<List<User>items={users}renderItem={(user) => (<div>{user.id}: {user.name}</div>)}/>);}
  • <List<User>> 显式指定了泛型类型 User
  • itemsUser[] 类型的数组。
  • renderItem 接收一个 User 类型的参数,并返回一个 React 节点。

四、泛型组件的高级用法

带默认类型的泛型组件

你可以为泛型参数提供默认类型,这样在使用组件时,如果未显式指定类型,TypeScript 会使用默认类型。

	interface ListProps<T = string> {items: T[];renderItem: (item: T) => React.ReactNode;}function List<T = string>({ items, renderItem }: ListProps<T>) {// ...同上...}// 使用默认类型(string)function App() {return (<Listitems={['Alice', 'Bob']}renderItem={(name) => <div>{name}</div>}/>);}
  • T = string 为泛型参数 T 提供了默认类型 string
  • 如果未显式指定泛型类型,TypeScript 会使用 string

多个泛型参数

泛型组件可以有多个类型参数:

	interface PairProps<T, U> {first: T;second: U;}	 function Pair<T, U>({ first, second }: PairProps<T, U>) {return (<div><div>First: {String(first)}</div><div>Second: {String(second)}</div></div>);}function App() {return <Pair<number, string> first={42} second="Hello" />;}
  • TU 是两个类型参数。
  • firstT 类型,secondU 类型。

五、泛型组件的实际应用场景

数据展示组件

泛型组件非常适合用于数据展示,如表格、列表等,可以处理多种数据类型。

表单组件

泛型组件可以用于表单组件,处理不同结构的表单数据。

状态管理

泛型组件可以用于编写通用的状态管理逻辑,适应多种数据类型。

注意事项

  1. 避免过度泛型化:过度使用泛型可能会使代码难以理解和维护。
  2. 类型安全:确保泛型组件的类型定义足够严格,以避免运行时错误。
  3. 文档:为泛型组件编写清晰的文档,说明泛型参数的用途和约束。

总结

React 结合 TypeScript 可以很好地支持泛型组件。泛型组件通过类型参数提供了灵活性、类型安全和可重用性,是编写高质量 React 代码的重要工具。合理使用泛型组件可以显著减少重复代码,提高开发效率。

通过本文的介绍,希望你对 React 泛型组件有了更深入的理解,并能在实际项目中灵活运用,打造出更加灵活且类型安全的 UI 组件。

相关文章:

React 泛型组件:用TS来打造灵活的组件。

文章目录 前言一、什么是泛型组件&#xff1f;二、为什么需要泛型组件&#xff1f;三、如何在 React 中定义泛型组件&#xff1f;基础泛型组件示例使用泛型组件 四、泛型组件的高级用法带默认类型的泛型组件多个泛型参数 五、泛型组件的实际应用场景数据展示组件表单组件状态管…...

TDengine 集群运行监控

简介 为了确保集群稳定运行&#xff0c;TDengine 集成了多种监控指标收集机制&#xff0c;并通过 taosKeeper 进行汇总。taosKeeper 负责接收这些数据&#xff0c;并将其写入一个独立的 TDengine 实例中&#xff0c;该实例可以与被监控的 TDengine 集群保持独立。TDengine 中的…...

图像任务中的并发处理:线程池、Ray、Celery 和 asyncio 的比较

在图像缺陷检测任务中&#xff0c;处理大量图像和点云数据时&#xff0c;高效的并发处理是关键。本文将介绍五种流行的并发处理方法&#xff1a;线程池&#xff08;concurrent.futures.ThreadPoolExecutor&#xff09;、Ray、Celery、asyncio以及搜狗Workflow&#xff0c;并从原…...

DeepSeek 赋能智能物流:解锁仓储机器人调度的无限可能

目录 一、智能物流仓储机器人调度现状1.1 传统调度面临的挑战1.2 现有智能调度的进展与局限 二、DeepSeek 技术探秘2.1 DeepSeek 核心技术原理2.2 DeepSeek 的独特优势 三、DeepSeek 在智能物流仓储机器人调度中的创新应用3.1 智能任务分配与调度3.2 路径规划与避障优化3.3 实时…...

C#上传图片后压缩

上传的图片尺寸不一&#xff0c;手机拍照的有2000*2000像素的&#xff0c;对实际使用来说 文件尺寸太大&#xff0c;文件也有近4M 下面是直接压缩的方法 1、安装包 Magick.NET-Q16-AnyCPU 2、上代码 /// <summary> /// 缩放图片 /// </summary> /// <param …...

uniapp路由跳转toolbar页面

需要阅读uview-ui的API文档 注意需要使用type参数设置后才起作用 另外route跳转的页面会覆盖toolbar工具栏 toConternt(aid) {console.log(aid:, aid)this.$u.route({// url: "pages/yzpg/detail",url: "pages/yzappl/index",// url: "pages/ind…...

【linux】知识梳理

操作系统的分类 1. 桌⾯操作系统: Windows/macOS/Linux 2. 移动端操作系统: Android(安卓)/iOS(苹果) 3. 服务器操作系统: Linux/Windows Server 4. 嵌⼊式操作系统: Android(底层是 Linux) Liunx介绍 liunx系统:服务器端最常见的操作系统类型 发行版:Centos和Ubuntu 远程连接操…...

PostgreSQL 内置扩展列表

PostgreSQL 内置扩展列表 PostgreSQL 自带了许多内置扩展&#xff08;built-in extensions&#xff09;&#xff0c;这些扩展提供了额外的功能而不需要额外安装。以下是主要的内置扩展分类和说明&#xff1a; 标准内置扩展&#xff08;随核心安装&#xff09; 1. 管理类扩展…...

NodeMediaEdge快速上手

NodeMediaEdge快速上手 简介 NodeMediaEdge是一款部署在监控摄像机网络前端中&#xff0c;拉取Onvif或者rtsp/rtmp/http视频流并使用rtmp/kmp推送到公网流媒体服务器的工具。 通过云平台协议注册到NodeMediaServer后&#xff0c;可以同NodeMediaServer结合使用。使用图形化的…...

ChatOn:智能AI聊天助手,开启高效互动新时代

在当今快节奏的生活中&#xff0c;无论是工作、学习还是日常交流&#xff0c;我们常常需要快速获取信息、整理思路并高效完成任务。ChatOn 正是为满足这些需求而生&#xff0c;它基于先进的 ChatGPT 和 GPT-4o 技术&#xff0c;为用户提供市场上最优秀的中文 AI 聊天机器人。这…...

基于Vue3.0的【Vis.js】库基本使用教程(002):图片知识图谱的基本构建和设置

文章目录 3、图片知识图谱3.1 初始化图片知识图谱3.2 修改节点形状3.3 修改节点背景颜色3.4 完整代码下载3、图片知识图谱 3.1 初始化图片知识图谱 1️⃣效果预览: 2️⃣关键代码: 给节点添加image属性: const nodes = ref([{id: 1,...

监督学习 vs 无监督学习:AI两大学习范式深度解析

监督学习 vs 无监督学习&#xff1a;AI两大学习范式深度解析 引言&#xff1a;机器如何"学习"&#xff1f; 想象教孩子识别动物&#xff1a;一种方法是展示图片并告诉名称&#xff08;监督学习&#xff09;&#xff0c;另一种是让孩子自己观察动物特征并分类&#…...

C# Costura.Fody 排除多个指定dll

按照网上的说在 FodyWeavers.xml 里修改 然后需要注意的是 指定多个排除项 不是加 | 是换行 一个换行 就排除一项 我测试的 <?xml version"1.0" encoding"utf-8"?> <Weavers xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance&quo…...

NodeJS全栈WEB3面试题——P8项目实战类问题(偏全栈)

&#x1f4e6; 8.1 请描述你做过的 Web3 项目&#xff0c;具体技术栈和你负责的模块&#xff1f; 我主导开发过一个基于 NFT 的数字纪念平台&#xff0c;用户可以上传照片并生成独特的纪念 NFT&#xff0c;结合 IPFS 和 ERC-721 实现永存上链。 &#x1f527; 技术栈&#xf…...

小白的进阶之路系列之五----人工智能从初步到精通pytorch张量

张量 张量是一种特殊的数据结构,与数组和矩阵非常相似。在PyTorch中,我们使用张量来编码模型的输入和输出,以及模型的参数。 张量类似于NumPy的ndarray,除了张量可以在gpu或其他硬件加速器上运行。事实上,张量和NumPy数组通常可以共享相同的底层内存,从而消除了复制数据…...

设计模式——迭代器设计模式(行为型)

摘要 本文详细介绍了迭代器设计模式&#xff0c;这是一种行为型设计模式&#xff0c;用于顺序访问集合对象中的元素&#xff0c;同时隐藏集合的内部结构。文章首先定义了迭代器设计模式并阐述了其核心角色&#xff0c;包括迭代器接口、具体迭代器、容器接口和具体容器。接着&a…...

android-studio-2024.3.2.14如何用WIFI连接到手机(给数据线说 拜拜!)

原文&#xff1a;Android不用数据线就能调试真机的方法—给数据线说 拜拜&#xff01;&#xff08;adb远程调试&#xff09; android-studio-2024.3.2.14是最新的版本&#xff0c;如何连接到手机&#xff0c;可用WIFI&#xff0c;可不用数据线&#xff0c;拜拜 第一步&#xf…...

[特殊字符] xbatis 一款好用 ORM 框架 1.8.8-M2 发布,节省 1/3 代码和时间的框架!!!

1.8.8-M2 更新内容: 1:优化默认值,对同一类减少重复调用2:优化分页,支持 limit (-1) 进行忽略分页3:优化 UpdateChain.set;支持.set (SysUser::getVersion, c -> c.plus (1))4:优化 @Fetch, 已增强,无法配置 groupby、forceUseIn(已去除)5:增强 @Fetch,支持中间…...

js 动画库、2048核心逻辑、面试题add[1][2][3]+4

1、js 动画库 web animation api &#xff08;1&#xff09;初始化代码 hmtl、css 部分 初始化全局背景黑色初始化黄色小球 js 部分 监听全局点击事件创建并添加元素 class"pointer" 的 div 标签 设置 left、top 位置监听动画结束事件&#xff0c;移除该元素 定位小…...

华为OD机试真题——书籍叠放(2025B卷:200分)Java/python/JavaScript/C/C++/GO最佳实现

2025 B卷 200分 题型 本专栏内全部题目均提供Java、python、JavaScript、C、C++、GO六种语言的最佳实现方式; 并且每种语言均涵盖详细的问题分析、解题思路、代码实现、代码详解、3个测试用例以及综合分析; 本文收录于专栏:《2025华为OD真题目录+全流程解析+备考攻略+经验分…...

PyTorch-Transforms的使用(二)

对图像进行处理 安装open cv ctrlP 看用法 ToTensor的使用 常见的Transforms 归一化的图片 两个长度为三的数组&#xff0c;分别表示三个通道的平均值和标准差 Resize&#xff08;&#xff09; Compose&#xff08;&#xff09; 合并执行功能&#xff0c;输入进去一个列表&a…...

Pytorch知识点2

Pytorch知识点 1、官方教程2、张量&#x1f9f1; 0、数组概念&#x1f9f1; 1. 创建张量&#x1f4d0; 2. 张量形状与维度&#x1f522; 3. 张量数据类型➗ 4. 张量的数学与逻辑操作&#x1f504; 5. 张量的就地操作&#x1f4e6; 6. 复制张量&#x1f680; 7. 将张量移动到加速…...

Java详解LeetCode 热题 100(23):LeetCode 206. 反转链表(Reverse Linked List)详解

文章目录 1. 题目描述1.1 链表节点定义 2. 理解题目2.1 反转前后对比2.2 核心思路 3. 解法一&#xff1a;迭代法&#xff08;三指针法&#xff09;3.1 算法思路3.2 详细图解3.3 Java代码实现3.4 代码执行过程演示3.5 执行结果示例3.6 优化版本&#xff08;简化代码&#xff09;…...

StarRocks部署方案详解:从单机到分布式集群

#### 一、引言 StarRocks&#xff08;原名DorisDB&#xff09;是一款高性能的MPP&#xff08;大规模并行处理&#xff09;分析型数据库&#xff0c;支持实时查询、高并发和复杂分析场景。其基于列式存储和向量化执行引擎的设计&#xff0c;使其在大数据OLAP领域表现优异。本文…...

AWS API Gateway 配置WAF(中国区)

问题 需要给AWS API Gateway配置WAF。 AWS WAF设置 打开AWS WAF首页&#xff0c;开始创建和配置WAF&#xff0c;如下图&#xff1a; 设置web acl名称&#xff0c;然后开始添加aws相关资源&#xff0c;如下图&#xff1a; 选择资源类型&#xff0c;但是&#xff0c;我这里出…...

【前端面经】百度一面

写在前面&#xff1a;面经只是记录博主遇到的题目。每题的答案在编写文档的时候已经有问过deepseek&#xff0c;它只是一种比较普世的答案&#xff0c;要学得深入还是靠自己 Q&#xff1a; <html><style>.a {background-color: red;width: 200px;height: 100px;}…...

嵌入式学习笔记 - freeRTOS 动态创建任务跟静态创建任务的区别,以及内存回收问题

‌FreeRTOS动态创建任务和静态创建任务各有优缺点&#xff0c;选择哪种方式取决于具体的应用场景和需求。‌ 一 动态创建任务 ‌优点‌&#xff1a; ‌灵活性高‌&#xff1a;动态任务在运行时通过pvPortMalloc()动态分配内存&#xff0c;系统自动管理栈和任务控制块&#xf…...

[免费]微信小程序网上花店系统(SpringBoot后端+Vue管理端)【论文+源码+SQL脚本】

大家好&#xff0c;我是java1234_小锋老师&#xff0c;看到一个不错的微信小程序网上花店系统(SpringBoot后端Vue管理端)【论文源码SQL脚本】&#xff0c;分享下哈。 项目视频演示 【免费】微信小程序网上花店系统(SpringBoot后端Vue管理端) Java毕业设计_哔哩哔哩_bilibili 项…...

如何给老旧 iOS App 添加安全保护?用 Ipa Guard 对 IPA 文件混淆加固实录

在大多数安全讨论中&#xff0c;我们习惯关注新项目的安全性&#xff0c;从代码结构、API 设计、用户认证机制出发&#xff0c;构建完善的防护体系。但现实是&#xff0c;很多开发者都在维护一些年久失修的老项目——技术架构老旧、团队成员流失、源码混乱甚至缺失。 我最近接…...

C#语音录制:使用NAudio库实现语音录制功能详解

C#语音录制&#xff1a;使用NAudio库实现语音录制功能详解 在音频处理领域&#xff0c;C# 凭借其强大的生态系统和丰富的类库&#xff0c;为开发者提供了便捷的开发工具。NAudio 库就是其中一款用于音频处理的优秀开源库&#xff0c;它支持多种音频格式和音频设备操作。今天&a…...