news 2026/5/1 13:19:21

TypeScript 基础类型

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
TypeScript 基础类型

TypeScript 基础类型详解

TypeScript 的类型系统是其核心优势,它提供了比 JavaScript 更严格、更安全的类型检查。以下是 TypeScript 中最常用的基础类型(primitive types 和常用组合类型),全部基于 TypeScript 5.x 版本。

1. 基本原始类型(Primitives)
类型描述示例代码说明
boolean布尔值let isActive: boolean = true;只有truefalse
number数字(包括整数、浮点数)let age: number = 30;
let pi: number = 3.14;
支持NaNInfinity
bigint大整数(ES2020+)let big: bigint = 100n;末尾加n
string字符串let name: string = "Alice";
let greeting: string =Hi ${name};
支持模板字符串
undefined未定义let u: undefined = undefined;严格模式下需注意
null空值let n: null = null;undefined不同
symbol唯一标识符let sym: symbol = Symbol("id");常用于对象属性键
2. any 类型(万能类型)
letanything:any=4;anything="string";// 任意类型都可赋值anything=true;// 不会报错anything.bark();// 也不会报错(但运行时可能出错)

注意any会关闭类型检查,不推荐滥用。尽量使用unknown替代。

3. unknown 类型(更安全的 any)
letunknownValue:unknown=4;// unknownValue.toFixed(); // 错误:必须先检查类型if(typeofunknownValue==="number"){console.log(unknownValue.toFixed(2));// OK}

unknown强制你进行类型检查或断言,安全性远高于any

4. 数组类型(Array)

两种写法等价:

letnumbers1:number[]=[1,2,3];// 推荐letnumbers2:Array<number>=[1,2,3];// 泛型写法

只读数组:

letreadonlyArr:ReadonlyArray<number>=[1,2,3];// readonlyArr.push(4); // 错误:只读
5. 元组类型(Tuple)

固定长度、固定类型顺序的数组:

letperson:[string,number]=["Alice",30];// person[2] = "extra"; // 错误:长度固定// 可选元素(TS 4.0+)letoptionalTuple:[string,number?]=["Bob"];
6. 对象类型(Object)

推荐使用interfacetype定义对象结构:

// 使用 interfaceinterfaceUser{name:string;age:number;isAdmin?:boolean;// 可选readonlyid:number;// 只读}letuser:User={name:"Charlie",age:28,id:1};// 使用 type(更灵活)typePoint={x:number;y:number;};letp:Point={x:10,y:20};
7. 联合类型(Union Types)

一个值可以是多种类型之一:

letid:string|number=123;id="abc";// OKfunctionprintId(id:string|number){if(typeofid==="string"){console.log(id.toUpperCase());}else{console.log(id.toFixed(2));}}
8. 字面量类型(Literal Types)

限制值为具体字面量:

typeStatus="success"|"error"|"loading";letstate:Status="success";// 只能是这三个值typeYesNo=true|false;typeZero=0;
9. 枚举(Enums)

定义一组命名常量:

enumDirection{Up,// 默认 0Down,// 1Left,// 2Right// 3}letdir:Direction=Direction.Up;console.log(Direction[0]);// "Up"(反向映射)

字符串枚举(推荐):

enumColor{Red="RED",Green="GREEN",Blue="BLUE"}
10. void 类型

表示函数无返回值:

functionlog(message:string):void{console.log(message);}
11. never 类型

表示永远不会正常返回:

functionthrowError(msg:string):never{thrownewError(msg);}functioninfiniteLoop():never{while(true){}}
12. 内置实用类型(Utility Types)——常用基础工具
类型作用示例
Partial<T>所有属性变为可选Partial<User>
Required<T>所有属性变为必选Required<User>
Readonly<T>所有属性变为只读Readonly<User>
Pick<T, K>挑选部分属性`Pick<User, “name”
Omit<T, K>排除部分属性Omit<User, "id">
Record<K, T>创建键值类型对象Record<string, number>
小结:常用类型速查
场景推荐类型写法
数字number
字符串string
布尔boolean
数组T[]Array<T>
对象interfacetype
多种可能`A
固定值`“success”
无返回值函数void
永远不返回never
任意类型(谨慎)unknown(推荐) >any

如果您想深入某个类型(如泛型、交叉类型、类型守卫、条件类型等),或者需要具体示例代码,请告诉我!

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

TypeScript 类

TypeScript 中的类&#xff08;Class&#xff09;详解 TypeScript 的类&#xff08;class&#xff09;基于 ES6 类语法&#xff0c;并添加了强大的静态类型支持、访问修饰符、抽象类、装饰器等特性&#xff0c;使其更接近传统面向对象语言&#xff08;如 Java/C#&#xff09;&…

作者头像 李华
网站建设 2026/5/1 5:48:48

Excalidraw手势操作支持情况(触屏/平板)

Excalidraw 手势操作支持深度解析&#xff08;触屏/平板&#xff09; 在远程协作日益成为常态的今天&#xff0c;团队对“随时随地白板讨论”的需求从未如此迫切。无论是产品原型草图、系统架构推演&#xff0c;还是线上教学演示&#xff0c;一个能自然响应手指或触控笔输入的虚…

作者头像 李华
网站建设 2026/5/1 6:56:35

Open-AutoGLM指令集优化实战(专家级调优技巧大公开)

第一章&#xff1a;Open-AutoGLM指令集优化概述Open-AutoGLM 是面向生成式语言模型推理过程的高性能指令集优化框架&#xff0c;旨在通过底层指令重构与硬件协同设计&#xff0c;显著提升大模型在边缘设备和通用服务器上的执行效率。该框架融合了动态算子融合、稀疏化感知执行与…

作者头像 李华
网站建设 2026/5/1 5:48:00

大数据技术的基于Python的王者荣耀战队的游戏数据分析系统设计与实现20240516--论文-爬虫 可视化

文章目录系统截图项目简介大数据系统开发流程主要运用技术介绍爬虫核心代码展示结论源码文档获取定制开发/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01;系统截图 大数据技术的基于Python的王者荣耀战队的游戏数据分析系统设计与实现20240516–论文…

作者头像 李华
网站建设 2026/5/1 5:48:07

5、图像打印、幻灯片制作与媒体播放指南

图像打印、幻灯片制作与媒体播放指南 一、图像打印 在计算机中打印图像是一项常见需求,以下是详细步骤: 1. 选择图像 :在“Pictures”文件夹中,选择想要打印的一张或多张图像。可以单独打印单张图像,也能选择多张图像,且多张图像既可以逐张打印,也能在每张纸上打印…

作者头像 李华
网站建设 2026/5/1 6:57:40

Excalidraw开源社区对AI功能的反馈汇总

Excalidraw开源社区对AI功能的反馈汇总 在远程协作日益成为常态的今天&#xff0c;技术团队、产品设计和教育工作者对可视化工具的需求早已不再局限于“能画图”——他们需要的是一个既能激发创意、又能快速表达想法的数字白板。Excalidraw 正是在这样的背景下脱颖而出&#x…

作者头像 李华