TypeScript7(元组)

在 TypeScript 中,元组(Tuple)是一种特殊的数组类型,它允许你明确地定义数组中每个元素的类型和数量。与普通数组不同,元组的长度是固定的,并且每个位置的类型都是预先确定的。

当你需要一个固定长度、且元素类型不完全相同的数组时,元组是比普通数组更具表达力和类型安全的选择。

1.元组的写法

元组的写法非常直观,你只需要在类型注解中使用方括号 [],并在其中列出每个元素的类型。

ts 复制代码
let person: [string, number];

赋值时,必须遵守定义的类型和顺序。

ts 复制代码
person = ["Alice", 25];
// console.log(person);// ["Alice", 25]

2.为什么使用元组?

元组的核心优势在于它提供了比数组更强的类型安全和结构化 ,它将数组的索引与元素的含义关联起来,让代码的意图更加清晰。
可以使用?来定义元组中的可选元素,但必须放在元组类型定义中的末尾

ts 复制代码
let optionalTuple: [string, number, boolean?]
optionalTuple = ["Alice", 25];
optionalTuple = ["Alice", 25, true];
// console.log(optionalTuple);// ["Alice", 25, true]

可以使用...type[]来定义元组的剩余元素,也必须放在元组类型定义中的末尾

ts 复制代码
let restTuple: [string, ...number[]]
restTuple = ['Alice'];
restTuple = ['Alice', 25, 30, 35];
// console.log(restTuple);// ["Alice", 25, 30, 35]

3.使用场景

栗子1:函数返回多个值

当你需要从一个函数返回多个、不同类型的值时,元组是很好的选择。例如,一个函数可能需要返回一个状态码(数字)和一条描述信息(字符串)。

ts 复制代码
const getStatus = (): [number, string] => {
    return [200, "OK"];
}

const [statusCode, message] = getStatus();
// console.log(statusCode, message);// 200 OK

栗子2:定义键值对

元组非常适合用来表示简单的键值对,例如 [key, value]。当你从一个 Map 或其他数据结构中迭代出键值对时,元组的结构非常清晰。

ts 复制代码
const userMap = new Map<string, number>();
userMap.set("Alice", 25);
userMap.set("Bob", 30);

for (const [name, age] of userMap.entries()) {
    console.log(`${name} is ${age} years old`);
}
// Alice is 25 years old
// Bob is 30 years old

栗子3:表示固定格式的数组

当你需要存储一组固定长度、固定类型的数据时,元组比对象更轻量。

ts 复制代码
let point: [number, number] = [10, 20];
let date: [number, number, number] = [2025, 8, 26]

4.元组与普通数组的区别

特性 元组(tuple) 普通数组(Array)
长度 固定长度 可变长度
类型 每个位置的类型可不同但固定 所有元素的类型都相同
用途 结构化数据,返回多个值 存储相同类型元素的集合
示例 [string,number] number[]或Array<number>
相关推荐
Hao_Harrision2 小时前
50天50个小项目 (React19 + Tailwindcss V4) ✨ | DragNDrop(拖拽占用组件)
前端·react.js·typescript·tailwindcss·vite7
许泽宇的技术分享4 小时前
解密Anthropic的MCP Inspector:从协议调试到AI应用开发的全栈架构之旅
人工智能·架构·typescript·mcp·ai开发工具
江澎涌7 小时前
鸿蒙 SDK 发布实战:JWorker 上架 ohpm 全流程
typescript·harmonyos·arkts
running up8 小时前
Java集合框架之ArrayList与LinkedList详解
javascript·ubuntu·typescript
AAA_bo19 小时前
liunx安装canda、python、nodejs、git,随后部署私有网页内容提取工具--JinaReader全攻略
linux·python·ubuntu·typescript·aigc·python3.11·jina
行走的陀螺仪1 天前
前端基建从0到1搭建步骤清单(含工具选型+配置要点+落地注意事项)
前端·javascript·typescript·设计规范·前端工程化·规范化·前端基建
ttod_qzstudio1 天前
Vue 3 的魔法:用 v-bind() 让 CSS 爱上 TypeScript 常量
css·vue.js·typescript
[seven]2 天前
React Router TypeScript 路由详解:嵌套路由与导航钩子进阶指南
前端·react.js·typescript
_Kayo_2 天前
TypeScript 学习笔记2
前端·javascript·typescript
[seven]2 天前
React Router TypeScript 路由详解:类型安全的路由配置与参数处理
安全·react.js·typescript