如何在 React 项目中应用 TypeScript?应该注意那些点?结合实际项目示例及代码进行讲解!
在 React 项目中应用 TypeScript 是提升开发效率、增强代码可维护性和可读性的好方法。TypeScript 提供了静态类型检查、自动补全和代码提示等功能,这对于 React 开发者来说,能够帮助早期发现潜在的 bug,提高开发体验。
1. 项目初始化
在现有的 React 项目中添加 TypeScript 或者在新项目中使用 TypeScript,最常见的两种方式:
1.1 使用 create-react-app
创建 TypeScript 项目
create-react-app
提供了一个简单的方式来初始化一个支持 TypeScript 的 React 项目。
npx create-react-app my-app --template typescript
这会生成一个默认的 React 项目,且已包含 TypeScript 配置。
1.2 在现有项目中添加 TypeScript
如果你已经有一个基于 JavaScript 的 React 项目,可以通过以下步骤将 TypeScript 添加到现有项目中:
- 安装 TypeScript 和类型声明文件:
npm install typescript @types/react @types/react-dom @types/jest --save-dev
- 在项目根目录下添加一个
tsconfig.json
文件。可以通过以下命令生成:
npx tsc --init
- 将
.js
文件重命名为.tsx
(如果文件中包含 JSX)或.ts
(如果没有 JSX)。
2. TypeScript 与 React 组件
在 React 中,组件的类型定义通常是使用接口(interface
)或者类型别名(type
)来定义 props 和 state。通过这些方式,TypeScript 可以帮助你在编写组件时验证 props 和 state 的类型。
2.1 函数组件的类型定义
import React from 'react';// 定义一个组件的 props 类型
interface MyComponentProps {name: string;age?: number; // 可选属性
}// 函数组件的定义
const MyComponent: React.FC<MyComponentProps> = ({ name, age }) => {return (<div><h1>Hello, {name}!</h1>{age && <p>Age: {age}</p>}</div>);
}export default MyComponent;
解析:
MyComponentProps
接口定义了组件的props
类型。React.FC<MyComponentProps>
表示该组件是一个函数组件,并且它接受MyComponentProps
类型的props
。age?
是一个可选的属性,如果没有传递age
,TypeScript 会自动推断它是undefined
。
2.2 类组件的类型定义
如果你使用类组件,你也可以使用 TypeScript 来定义 props
和 state
类型:
import React, { Component } from 'react';interface MyComponentProps {name: string;
}interface MyComponentState {count: number;
}class MyComponent extends Component<MyComponentProps, MyComponentState> {constructor(props: MyComponentProps) {super(props);this.state = { count: 0 };}increment = () => {this.setState({ count: this.state.count + 1 });}render() {const { name } = this.props;const { count } = this.state;return (<div><h1>Hello, {name}!</h1><p>Count: {count}</p><button onClick={this.increment}>Increment</button></div>);}
}export default MyComponent;
解析:
MyComponentProps
定义了props
的类型。MyComponentState
定义了组件的state
类型。- 在类组件中,
Component
接受两个泛型参数,第一个是props
的类型,第二个是state
的类型。
3. State 和事件类型
TypeScript 也会帮助你类型化组件中的 state
和事件处理函数。
3.1 使用 useState
钩子
useState
是 React 中的一个常用钩子。为了让 TypeScript 知道 state
的类型,你可以显式指定 useState
的类型:
import React, { useState } from 'react';const Counter: React.FC = () => {const [count, setCount] = useState<number>(0); // 显式指定类型const increment = () => setCount(count + 1);const decrement = () => setCount(count - 1);return (<div><p>Count: {count}</p><button onClick={increment}>Increment</button><button onClick={decrement}>Decrement</button></div>);
};export default Counter;
解析:
useState<number>(0)
显式指定state
为number
类型,TypeScript 会确保count
变量是一个数字。- 这样可以避免在
setCount
中传递非数字类型的值。
3.2 使用事件类型
对于 React 中的事件处理函数,TypeScript 提供了详细的类型定义。你可以通过类型注解来确保事件对象的正确性。
import React from 'react';const MyButton: React.FC = () => {const handleClick = (event: React.MouseEvent<HTMLButtonElement>) => {console.log('Button clicked', event);};return <button onClick={handleClick}>Click Me</button>;
};export default MyButton;
解析:
handleClick
函数的event
参数被类型化为React.MouseEvent<HTMLButtonElement>
,它确保事件对象是一个鼠标点击事件,并且目标是一个按钮元素。
4. 类型定义文件(@types)
对于一些第三方库,TypeScript 需要通过类型声明文件来理解它们的类型。大多数流行的 React 库,如 react-router
, axios
等,都提供了类型定义文件(@types
)。
例如,使用 axios
时,安装相关的类型声明:
npm install axios @types/axios
安装后,TypeScript 会自动识别 axios
的类型定义。
5. TypeScript 和 JSX
如果你的组件中有 JSX,你需要确保 .tsx
文件的类型正确。如果没有 JSX,那么你只需要使用 .ts
文件。
5.1 类型检查 JSX 元素
你可以通过 TypeScript 对 JSX 元素进行类型检查。确保你的组件接受的 props
和传递的元素都符合预期的类型。
import React from 'react';interface BoxProps {color: 'red' | 'blue' | 'green'; // 限定 color 为特定值
}const Box: React.FC<BoxProps> = ({ color }) => {return <div style={{ backgroundColor: color }}>I am a {color} box</div>;
};export default Box;
解析:
color
属性只允许'red'
,'blue'
, 或'green'
,TypeScript 会在编译时检查传递给组件的值是否在这些选项之内。
6. React 与 TypeScript 使用中的注意点
- 避免
any
类型:尽量避免使用any
类型。虽然any
可以绕过 TypeScript 的类型检查,但它会失去类型安全的意义。尽量使用更具体的类型或者类型推导。 - 使用
React.FC
时的警告:React.FC
是 React 提供的函数组件类型定义,虽然它可以简化类型声明,但它也有一些限制,如自动推断children
,有时会引起不必要的困扰。在某些情况下,可以使用自定义接口代替。 - Props 和 State 类型:对于复杂的 props 和 state,使用接口(
interface
)定义类型会更加清晰。对于简单的类型,可以使用类型别名(type
)。 - 类型推导:TypeScript 在大多数情况下能够自动推导变量的类型,因此尽量依赖 TypeScript 的推导,而不是显式类型声明,只有在需要明确类型时才指定类型。
总结
在 React 项目中使用 TypeScript 能够显著提高代码的可读性和可维护性。通过合理地使用 TypeScript 的类型系统,能在编译时捕获错误,减少运行时 bug。类型检查不仅可以提高代码的健壮性,还能帮助开发者更好地理解组件的期望输入和输出。
在实际项目中,你应该:
- 明确地定义每个组件的
props
和state
类型。 - 在函数和事件处理器中使用合适的类型注解。
- 尽量避免使用
any
类型,尽可能让 TypeScript 进行类型推导。 - 使用 TypeScript 对第三方库和框架进行类型管理,以提高开发效率。
相关文章:
如何在 React 项目中应用 TypeScript?应该注意那些点?结合实际项目示例及代码进行讲解!
在 React 项目中应用 TypeScript 是提升开发效率、增强代码可维护性和可读性的好方法。TypeScript 提供了静态类型检查、自动补全和代码提示等功能,这对于 React 开发者来说,能够帮助早期发现潜在的 bug,提高开发体验。 1. 项目初始化 在现…...

C++学习第四天
创作过程中难免有不足,若您发现本文内容有误,恳请不吝赐教。 提示:以下是本篇文章正文内容,下面案例可供参考 一、计算类对象的大小 #include<iostream> using namespace std;class Date { public:void Init(int year, in…...

【从零开始的LeetCode-算法】3232. 判断是否可以赢得数字游戏
给你一个 正整数 数组 nums。 Alice 和 Bob 正在玩游戏。在游戏中,Alice 可以从 nums 中选择所有个位数 或 所有两位数,剩余的数字归 Bob 所有。如果 Alice 所选数字之和 严格大于 Bob 的数字之和,则 Alice 获胜。 如果 Alice 能赢得这场游…...
一种简单高效的RTSP流在线检测方法,不需要再过渡拉流就可以获取设备状态以及对应音视频通道与编码格式
平台如何检测一路RTSP流是否在线? 在之前的流媒体平台方案中,我们都是通过定时RTSP拉流的方式,走一个完整的RTSP流程:包括OPTIONS、DESCRIBE、SETUP、PLAY、RTP收流,这种方式去取流,然后取到流之后进行流解…...

24/11/22 项目拆解 艺术风格转移
我们有时候想把两种艺术风格整合,创造更具艺术特色的艺术品,人很难办到,但是人工智能可以,比如下面将艺术画的风格转移到照片上。 我们先来初步了解一下实现上述功能的数学原理 所谓艺术风格,其实就是边缘,颜色&#…...

数字赋能,气象引领 | 气象景观数字化服务平台重塑京城旅游生态
在数字化转型的浪潮中,旅游行业正以前所未有的速度重塑自身,人民群众对于高品质、个性化旅游服务需求的日益增长,迎着新时代的挑战与机遇,为开展北京地区特色气象景观预报,打造“生态气象旅游”新业态,助推…...

关于Redux的学习(包括Redux-toolkit中间件)
目录 什么是 Redux ? 我为什么要用 Redux ? 我什么时候应该用 Redux ? Redux 库和工具 React-Redux Redux Toolkit Redux DevTools 拓展 一个redux小示例 代码示例(很有用): Redux 术语 Actions Reducers Store Dis…...
【无人机】
GJI Mini 4 Pro学习 首次飞行使用 01 开箱 打开长飞套装 依次取出产品及配件 飞行器、DJI RC - N2(DJI RC 2)、桨叶/螺丝、云台保护罩、束桨器、电池、螺丝刀、USB-C快接线、单肩包、USB-C数据线、充电管家 02 准备飞行器 取下束桨器,…...

Zabbix7.0.6的容器镜像准备
准备Zabbix7.0.6部署所需的容器镜像。 更新时间:20241122 一、准备数据库镜像 1、核对版本支持 根据Zabbix官网文档requirements 可知,当前最新的Zabbix 7.0.6对PostgreSQL数据库的要求如下: support for PostgreSQL versions:- 17.X …...

利用 GitHub 和 Hexo 搭建个人博客【保姆教程】
利用 GitHub 和 Hexo 搭建个人博客 利用 GitHub 和 Hexo 搭建个人博客一、前言二、准备工作(一)安装 Node.js 和 Git(二)注册 GitHub 账号 三、安装 Hexo(一)创建博客目录(二)安装 H…...
React第四节 组件的三大属性之state
前言 状态 state适用于类式组件中,而再函数式组件中需要使用 useState HOOK 模拟状态; React的组件就是一个状态机,通过与用户的交互,实现不同的状态,根据不同的状态展现出不一样的UI视图 并不是组件中所有的属性 都是组件的状态…...

MongoDB进阶篇-索引(索引概述、索引的类型、索引相关操作、索引的使用)
文章目录 1. 索引概述2. 索引的类型2.1 单字段索引2.2 复合索引2.3 其他索引2.3.1 地理空间索引(Geospatial Index)2.3.2 文本索引(Text Indexes)2.3.3 哈希索引(Hashed Indexes) 3. 索引相关操作3.1 查看索…...

使用FFmpeg实现视频与GIF的画中画效果
用FFmpeg命令行工具将GIF动画作为画中画(Picture-in-Picture,简称PiP)叠加到视频上。FFmpeg是一个强大的多媒体框架,能够处理几乎所有格式的音频和视频文件。通过这个教程,你将学会如何将一个小的GIF动画循环播放&…...
车载信息安全框架 --- 车载信息安全相关事宜
我是穿拖鞋的汉子,魔都中坚持长期主义的汽车电子工程师。 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 所有人的看法和评价都是暂时的,只有自己的经历是伴随一生的,几乎所有的担忧和畏惧,都是来源于自己的想象,只有你真的去做了,才会发现有多快乐。…...

Unreal5从入门到精通之EnhancedInput增强输入系统详解
前言 从Unreal5开始,老版的输入系统,正式替换为EnhancedInput增强型输入系统,他们之间有什么区别呢? 如果有使用过Unity的同学,大概也知道,Unity也在2020版本之后逐渐把输入系统也升级成了新版输入系统,为什么Unreal和Unity都热衷于升级输入系统呢?这之间又有什么联系…...

泛微E9与金蝶云星空的集成方案:实现审批流程与财务管理的无缝对接
泛微E9与金蝶云星空的集成方案:实现审批流程与财务管理的无缝对接 背景介绍: 在企业日常运营中,泛微OA-E9和金蝶云星空是两个关键的系统。泛微OA-E9是一款广受企业青睐的办公自动化软件,它通过流程管理、文档管理、协同办公等模…...
理解设计模式与 UML 类图:构建稳健软件架构的基石
在软件开发的广阔天地里,设计模式与 UML(统一建模语言)类图犹如两座灯塔,为开发者照亮前行的道路,指引着我们构建出高质量、可维护且易于扩展的软件系统。今天,就让我们一同深入探索单一职责、开闭原则、简…...

FastAPI重载不生效?解决PyCharm中Uvicorn无法重载/重载缓慢的终极方法!
文章目录 📖 介绍 📖🏡 演示环境 🏡📒 重载缓慢 📒📝 问题概述🚨 相关原因📝 解决方案一📝 解决方案二📝 解决方案三📝 解决方案四⚓️ 相关链接 ⚓️📖 介绍 📖 在使用FastAPI开发时,reload=True 本应让你在修改代码后自动重启服务,提升开发效率…...

最新子比主题zibll8.0开心版源码 无加密无后门
Zibll子比主题专为博客、自媒体及资讯类网站精心打造,以其简约而不失高雅的设计风格,为网站增添独特魅力与视觉美感。 8.0更新内容: 新增发帖选择板块、话题、标签时支持搜索,同时优化了选择栏目,更加方便快捷 新增小工具文章列表…...

【数据分析】认清、明确
1、什么是数据分析。 - 通过对大量的数据进行科学的分析。 - 得出结论,提出建议,辅助公司企业的决策。2、数据分析分为几步。 - 1.明确目的! - 2.收集数据!自己的数据! 自动化采集的数据! - 3.数据处理! - 4.数据分析!数据分析(业务)数据挖掘(代码算法…...

Docker 离线安装指南
参考文章 1、确认操作系统类型及内核版本 Docker依赖于Linux内核的一些特性,不同版本的Docker对内核版本有不同要求。例如,Docker 17.06及之后的版本通常需要Linux内核3.10及以上版本,Docker17.09及更高版本对应Linux内核4.9.x及更高版本。…...

python打卡day49
知识点回顾: 通道注意力模块复习空间注意力模块CBAM的定义 作业:尝试对今天的模型检查参数数目,并用tensorboard查看训练过程 import torch import torch.nn as nn# 定义通道注意力 class ChannelAttention(nn.Module):def __init__(self,…...

聊聊 Pulsar:Producer 源码解析
一、前言 Apache Pulsar 是一个企业级的开源分布式消息传递平台,以其高性能、可扩展性和存储计算分离架构在消息队列和流处理领域独树一帜。在 Pulsar 的核心架构中,Producer(生产者) 是连接客户端应用与消息队列的第一步。生产者…...

CentOS下的分布式内存计算Spark环境部署
一、Spark 核心架构与应用场景 1.1 分布式计算引擎的核心优势 Spark 是基于内存的分布式计算框架,相比 MapReduce 具有以下核心优势: 内存计算:数据可常驻内存,迭代计算性能提升 10-100 倍(文档段落:3-79…...

Cilium动手实验室: 精通之旅---20.Isovalent Enterprise for Cilium: Zero Trust Visibility
Cilium动手实验室: 精通之旅---20.Isovalent Enterprise for Cilium: Zero Trust Visibility 1. 实验室环境1.1 实验室环境1.2 小测试 2. The Endor System2.1 部署应用2.2 检查现有策略 3. Cilium 策略实体3.1 创建 allow-all 网络策略3.2 在 Hubble CLI 中验证网络策略源3.3 …...

UR 协作机器人「三剑客」:精密轻量担当(UR7e)、全能协作主力(UR12e)、重型任务专家(UR15)
UR协作机器人正以其卓越性能在现代制造业自动化中扮演重要角色。UR7e、UR12e和UR15通过创新技术和精准设计满足了不同行业的多样化需求。其中,UR15以其速度、精度及人工智能准备能力成为自动化领域的重要突破。UR7e和UR12e则在负载规格和市场定位上不断优化…...

Redis数据倾斜问题解决
Redis 数据倾斜问题解析与解决方案 什么是 Redis 数据倾斜 Redis 数据倾斜指的是在 Redis 集群中,部分节点存储的数据量或访问量远高于其他节点,导致这些节点负载过高,影响整体性能。 数据倾斜的主要表现 部分节点内存使用率远高于其他节…...
【HarmonyOS 5 开发速记】如何获取用户信息(头像/昵称/手机号)
1.获取 authorizationCode: 2.利用 authorizationCode 获取 accessToken:文档中心 3.获取手机:文档中心 4.获取昵称头像:文档中心 首先创建 request 若要获取手机号,scope必填 phone,permissions 必填 …...

Reasoning over Uncertain Text by Generative Large Language Models
https://ojs.aaai.org/index.php/AAAI/article/view/34674/36829https://ojs.aaai.org/index.php/AAAI/article/view/34674/36829 1. 概述 文本中的不确定性在许多语境中传达,从日常对话到特定领域的文档(例如医学文档)(Heritage 2013;Landmark、Gulbrandsen 和 Svenevei…...
SQL慢可能是触发了ring buffer
简介 最近在进行 postgresql 性能排查的时候,发现 PG 在某一个时间并行执行的 SQL 变得特别慢。最后通过监控监观察到并行发起得时间 buffers_alloc 就急速上升,且低水位伴随在整个慢 SQL,一直是 buferIO 的等待事件,此时也没有其他会话的争抢。SQL 虽然不是高效 SQL ,但…...