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>
相关推荐
森G4 小时前
TypeScript 基础类型
开发语言·typescript
烛阴12 小时前
用 MCP 调教 AI 代理:让 Cocos Creator 3.8.8 核心逻辑一键全自动生成
typescript·cocos creator
Rain50918 小时前
mini-cc 技术栈:跟着 Claude Code 先选 TypeScript + React + Ink
前端·javascript·react.js·typescript·node.js·ai编程
yantuguiguziPGJ19 小时前
WeMed:一个医疗垂直领域大模型 问答系统的 Taro 小程序
typescript·node.js
tedcloud1231 天前
wifi-densepose部署教程:构建无线人体感知系统
服务器·javascript·网络·typescript·ocr
奇奇怪怪的问题1 天前
学习ts笔记(二):属性修饰符,泛型,接口
前端·typescript
阿正的梦工坊2 天前
【Typescript】04-数组元组枚举与字面量类型
javascript·ubuntu·typescript
狼丶宇先森2 天前
vue-sign-canvas v2 重构复盘:从 Vue 2 签名板到 Vue 3 + TypeScript 组件库
前端·vue.js·重构·typescript·开源软件·canvas
muddjsv2 天前
前端开发语言使用流行度排行与分析
前端·javascript·typescript
Joy T2 天前
【Web3】Hardhat工程架构中Solidity与TypeChain的协作机制
git·架构·typescript·web3·智能合约·hardhat·typechain