0

0

在 React 函数式组件中应用泛型

聖光之護

聖光之護

发布时间:2025-08-17 23:44:01

|

413人浏览过

|

来源于php中文网

原创

在 react 函数式组件中应用泛型

本文介绍了如何在 React 函数式组件中使用泛型,以创建更灵活、可复用的组件。通过将类型参数传递给组件,可以使其处理不同类型的数据,避免代码冗余。同时,针对 string | number 联合类型在 useState 中遇到的问题,提供了两种解决方案,帮助开发者更好地掌握 React 类型系统。

在 React 中,使用 TypeScript 可以显著提高代码的可维护性和可读性。泛型是一种强大的工具,可以创建可重用的组件,这些组件可以处理各种数据类型,而无需为每种类型编写不同的组件。本文将详细介绍如何在 React 函数式组件中使用泛型,并解决一些常见问题。

泛型组件的创建

假设我们有一个 TestComponent 组件,它接收一个 options 数组,其中 options 的 value 属性可以是 string 或 number 类型。

首先,定义 Option 接口:

interface Option {
  value: string | number;
  label: string;
}

然后,定义 TestComponentProps 接口:

interface TestComponentProps {
  name: string;
  options: Option[];
  value: string | number;
  onChange: (value: string) => void;
}

最后,创建 TestComponent 组件:

import { FC } from "react";

export const TestComponent: FC = ({
  name,
  options,
  value,
  onChange,
}) => {
  return 
test component
; };

联合类型与 useState 的问题

在使用 string | number 联合类型时,可能会遇到与 useState 相关的问题。例如:

function App() {
  const [color, setColor] = useState("red");

  return (
    
setColor(c)} /> console.log("v", v)} />
); }

上述代码可能会产生一个错误:

极限网络办公Office Automation
极限网络办公Office Automation

专为中小型企业定制的网络办公软件,富有竞争力的十大特性: 1、独创 web服务器、数据库和应用程序全部自动傻瓜安装,建立企业信息中枢 只需3分钟。 2、客户机无需安装专用软件,使用浏览器即可实现全球办公。 3、集成Internet邮件管理组件,提供web方式的远程邮件服务。 4、集成语音会议组件,节省长途话费开支。 5、集成手机短信组件,重要信息可直接发送到员工手机。 6、集成网络硬

下载
Argument of type 'string | number' is not assignable to parameter of type 'SetStateAction'. Type 'number' is not assignable to type 'SetStateAction'

这是因为 useState 的初始值 "red" 确定了 color 状态的类型为 string。因此,setColor 只能接受 string 类型的参数。

解决方案

解决此问题有两种方法:

  1. 更改 onChange 参数类型: 将 TestComponentProps 接口中 onChange 的参数类型更改为 string。

    interface TestComponentProps {
      name: string;
      options: Option[];
      value: string | number;
      onChange: (value: string) => void;
    }

    这种方法简单直接,但限制了 onChange 只能处理 string 类型的值。

  2. 更改 useState 的类型: 使用泛型来指定 useState 的类型为 string | number。

    const [color, setColor] = useState("red");

    这种方法更灵活,允许 color 状态存储 string 或 number 类型的值。

总结

通过本文,我们学习了如何在 React 函数式组件中使用泛型,以及如何解决 string | number 联合类型与 useState 结合使用时遇到的问题。选择哪种解决方案取决于具体的需求和场景。理解这些概念可以帮助开发者编写更健壮、可维护的 React 代码。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
数据类型有哪几种
数据类型有哪几种

数据类型有整型、浮点型、字符型、字符串型、布尔型、数组、结构体和枚举等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

309

2023.10.31

php数据类型
php数据类型

本专题整合了php数据类型相关内容,阅读专题下面的文章了解更多详细内容。

222

2025.10.31

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

463

2023.08.02

硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1133

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

213

2025.10.17

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1828

2025.12.29

java接口相关教程
java接口相关教程

本专题整合了java接口相关内容,阅读专题下面的文章了解更多详细内容。

20

2026.01.19

java入门学习合集
java入门学习合集

本专题整合了java入门学习指南、初学者项目实战、入门到精通等等内容,阅读专题下面的文章了解更多详细学习方法。

1

2026.01.29

java配置环境变量教程合集
java配置环境变量教程合集

本专题整合了java配置环境变量设置、步骤、安装jdk、避免冲突等等相关内容,阅读专题下面的文章了解更多详细操作。

2

2026.01.29

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
TypeScript 教程
TypeScript 教程

共19课时 | 2.5万人学习

TypeScript——十天技能课堂
TypeScript——十天技能课堂

共21课时 | 1.1万人学习

TypeScript-45分钟入门
TypeScript-45分钟入门

共6课时 | 0.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号