news 2026/1/1 11:59:54

300TypeScript基础知识

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
300TypeScript基础知识

主要学习react中ts的使用和概念


第一阶段:Ts基础

TypeScript 的核心思想是:给变量穿上约束的衣服

1. 原始类型、数组、元组

letname:string="Gemini";letage:number=25;letisAI:boolean=true;// 数组的两种写法letskills:string[]=['React','TS'];letscores:Array<number>=[90,85];// 元组 (Tuple):固定长度和类型的数组letuser:[number,string]=[1,'Admin'];

2. 函数的定义

//普通函数定义functionadd(x:number,y:number):number{returnx+y;}letmyAdd=function(x:number,y:number):number{returnx+y;};
// 定义函数类型typeGreetFn=(name:string)=>string;constsayHello:GreetFn=(n)=>`Hello,${n}`;

3. 接口 (Interface) vs 类型别名 (Type)

  • Interface: 侧重于描述对象的结构,支持继承(extends)和声明合并。

  • Type: 更灵活,可以定义基本类型、联合类型、元组等。

interfaceLabelledValue{label:string;num?:number;}

这是最常用的功能,用于定义对象的结构。

特性InterfaceType
核心用途定义对象的形状定义任何类型(联合、元组等)
扩展方式使用extends关键字使用&(交叉类型)
重复定义会自动合并(Declaration Merging)不允许重复定义

建议:定义公共 API 或组件 Props 时优先使用interface;定义复杂逻辑、联合类型时使用type


4. 联合类型与字面量

// 联合类型:变量可以是多种类型之一letstatus:"loading"|"success"|"error";letcurrentStatus:Status="loading";// 只能是这三个字符串之一// 类型守卫 (Type Guard)functionprintId(id:number|string){if(typeofid==="string"){console.log(id.toUpperCase());// 此时 TS 知道 id 是 string}else{console.log(id.toFixed());// 此时 TS 知道 id 是 number}}

5. 泛型 Generics

泛型是 TS 最强大的地方,它允许你在定义时不指定具体类型,而在使用时动态决定。

// 这里的 T 就像是一个变量占位符functionidentity<T>(arg:T):T{returnarg;}constres1=identity<string>("hello");// T 被确定为 stringconstres2=identity<number>(100);// T 被确定为 number

第二阶段:React中应用


第一部分:TypeScript 语言核心

1. 类型系统的等级制度

在 TS 中,类型是有层级的。理解这一点能帮你解决 90% 的类型兼容性问题。

  • Top Types (顶级类型):anyunknown

  • any: 彻底放弃检查,是代码中的“黑洞”。

  • unknown: 虽也是万能类型,但在使用前必须进行类型检查(类型收窄)。

  • Bottom Type (底层类型):never。表示永远不会出现的值。常用于穷举检查。

2. Interface 与 Type 的深度对峙

在 React 项目中,两者的界限日益模糊,但底层逻辑不同:

  • Interface (面向对象): 描述“形状”。它支持声明合并(Declaration Merging)。如果你定义了两个同名的 Interface,TS 会自动把它们合二为一。这在扩展第三方库的类型时非常有用。
  • Type (函数式/代数): 描述“别名”。它更强大,可以使用联合(|)、交叉(&)、位运算等。Type 不能被重新打开添加属性

第二部分:工程化配置

tsconfig.json决定了你的代码如何被“审判”。以下是生产环境中最关键的三个配置:

配置项作用为什么重要
strict: true开启所有严格模式防止null导致的运行时崩溃,禁用隐式any
noImplicitAny禁止隐式 any强制你思考每个变量的来源,是项目质量的底线。
paths路径别名../../../../components简化为@/components,解耦目录结构。

第三部分:React + TS 实战兵法

1. 组件 Props 的“三板斧”

在定义组件 Props 时,利用 TS 的特性可以极大提升开发体验。

interface GreetProps { name: string; // 1. 可选属性 priority?: number; // 2. 字面量联合类型:限制范围 theme: 'dark' | 'light'; // 3. 复杂对象:引用其他接口 metadata: Record<string, unknown>; } // 推荐写法:使用普通函数解构 Props export const Greet = ({ name, theme = 'light' }: GreetProps) => { return <div className={theme}>Hello {name}</div>; };

2. Hooks 的高阶标注

Hooks 是 React 的核心,其类型标注主要依靠泛型

  • useState:
// 显式指定联合类型,处理“空状态” const [user, setUser] = useState<User | null>(null);
  • useRef:
    有两个场景:
  1. DOM 引用:const inputRef = useRef<HTMLInputElement>(null);(注意初始化为null)。
  2. 变量保存:const timerRef = useRef<number>();

3. 事件系统的“精确打击”

不要直接使用any处理事件。React 提供了一整套事件类型,命名规则通常是React.[事件名]Event<HTML元素类型>

const handleInputChange = (e: React.ChangeEvent<HTMLInputElement>) => { console.log(e.target.value); // 这里 e.target 会被精准推断为 HTMLInputElement };

第四部分:类型进阶

1. 工具类型 (Utility Types) 的降维打击

TS 内置的工具类型其实就是类型函数

  • Partial<T>: 把所有 Props 变可选。
  • Omit<T, 'id'>: 复制 T 的所有属性,但剔除id
  • Pick<T, 'title' | 'desc'>: 只从 T 中挑选部分属性。

2. 泛型组件 (Generic Components)

当你需要组件支持多种类型的数据流时(如自定义下拉框、表格):

interface SelectProps<T> { options: T[]; onSelect: (value: T) => void; } // 在函数名前使用 <T,> 开启泛型 export const Select = <T,>({ options, onSelect }: SelectProps<T>) => { return ( <ul> {options.map((opt, i) => ( <li key={i} onClick={() => onSelect(opt)}>选择</li> ))} </ul> ); }; // 使用时,TS 会根据传入的 options 自动推断 T <Select options={[1, 2, 3]} onSelect={(val) => console.log(val + 1)} />

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2025/12/25 5:06:21

Docker入门

Docker是一款快速构建、运行、管理应用的工具自动搜索并下载应用镜像。镜像不仅包含应用本身&#xff0c;还包含应用运行所需要的环境&#xff0c;配置&#xff0c;系统函数库、Docker会在运行镜像时创建一个隔离环境&#xff0c;称为容器。镜像仓库&#xff1a;Docker Hub入门…

作者头像 李华
网站建设 2025/12/18 20:59:00

22、正则表达式:从基础到高级应用

正则表达式:从基础到高级应用 1. 正则表达式基础 正则表达式除了字面字符外,还包含元字符,用于指定更复杂的匹配规则。常见的元字符有: ^ $ . [ ] { } - ? * + ( ) | \ ,其他字符则被视为字面字符。不过,反斜杠字符在某些情况下用于创建元序列,也可让元字符被当作字…

作者头像 李华
网站建设 2025/12/21 15:13:04

取能模块:无源自取电创新解决方案

提及无源自取电&#xff0c;很多人会第一时间联想到智能手机的无线充电功能&#xff0c;原则上理解的没错&#xff0c;只是相较于无源自取电这种技术&#xff0c;二者本质上应用的领域有所区别。前者目前适用于中高压和低压输电线路上&#xff0c;以非接触式取能的核心优势&…

作者头像 李华
网站建设 2025/12/18 20:58:22

30、编写Shell脚本入门与项目实践

编写Shell脚本入门与项目实践 1. 编写第一个脚本 首先,我们来编写一个简单的“Hello World”脚本。在命令行中输入以下代码: [me@linuxbox ~]$ echo Hello World! # This is a comment too Hello World!这里的注释在命令行中作用不大,但在脚本里是很有用的。脚本的第一行…

作者头像 李华
网站建设 2025/12/18 20:55:05

启动进程,并返回新进程id(C++源码)

1、概述 启动进程,并返回新进程id,支持场景: 1、支持绝对路径: C:\Program Files\Google\Chrome\Application\chrome.exe 2、支持环境变量路径:%localappdata%\\Feishu\\Feishu.exe 1.1、调用示例 // 调用示例// 启动进程,并返回新进程id// 支持绝对路径: C:\Program Fil…

作者头像 李华
网站建设 2025/12/18 20:51:20

PDF压缩

winnzip项目pdf压缩部分/*** 压缩PDF文件* param inputFile 输入PDF文件路径* param outputFile 输出PDF文件路径* param compressionLevel 压缩等级: 0小尺寸, 1中等尺寸, 2大尺寸* param lossless 是否无损压缩* return 压缩是否成功*/使用Ghostscript命令行方式进行pdf压缩&…

作者头像 李华