TypeScript 元组
我们知道数组中元素的数据类型都一般是相同的(any[] 类型的数组可以不同),如果存储的元素数据类型不同,则需要使用元组。
TypeScript 中的元组(Tuple)是一种特殊类型的数组,它允许在数组中存储不同类型的元素,与普通数组不同,元组中的每个元素都有明确的类型和位置。元组可以在很多场景下用于表示固定长度、且各元素类型已知的数据结构。
创建元组的语法格式如下:
let tuple: [类型1, 类型2, 类型3, ...];
实例
声明一个元组并初始化:
let mytuple: [number, string]; mytuple = [42,"Runoob"];
在上面的例子中,mytuple 是一个元组,它包含一个 number 类型和一个 string 类型的元素。
访问元组
元组中元素使用索引来访问,第一个元素的索引值为 0,第二个为 1,以此类推第 n 个为 n-1,语法格式如下:
tuple_name[index]
实例
以下实例定义了元组,包含了数字和字符串两种类型的元素:
TypeScript
编译以上代码,得到以下 JavaScript 代码:
JavaScript
输出结果为:
42 Runoob true
元组运算
我们可以使用以下两个函数向元组添加新元素或者删除元素:
push() 向元组添加元素,添加在最后面。
pop() 从元组中移除元素(最后一个),并返回移除的元素。
push 方法可以向元组的末尾添加一个元素,类型必须符合元组定义中的类型约束。如果超出元组的类型约束,TypeScript 会报错。
TypeScript
编译以上代码,得到以下 JavaScript 代码:
JavaScript
输出结果为:
[ 42, 'Hello', 'World' ]
pop 方法从元组的末尾移除一个元素,并返回该元素。返回的元素类型将根据元组的定义类型推断。
实例
// 移除最后一个元素
let lastElement = tuple.pop();
console.log(lastElement); // 输出: true
console.log(tuple); // 输出: [42, "Hello"]
更新元组
元组是可变的,这意味着我们可以对元组进行更新操作:
TypeScript
编译以上代码,得到以下 JavaScript 代码:
JavaScript
输出结果为:
元组的第一个元素为:42 元组中的第一个元素更新为:121
解构元组
我们也可以把元组元素赋值给变量,如下所示:
TypeScript
编译以上代码,得到以下 JavaScript 代码:
JavaScript
输出结果为:
42 Hello
使用标签元组
TypeScript 还允许为元组中的每个元素添加标签,这使得元组的含义更加清晰:
let tuple: [id: number, name: string] = [1, "John"];
在这个例子中,id 和 name 是元组的标签,可以让代码更加可读。
元组的实际应用
元组常用于函数返回多个值的场景,或者表示某些固定结构的数据,比如:
实例
return [1, "John Doe"];
}
const [userId, userName] = getUserInfo();
console.log(userId); // 输出: 1
console.log(userName); // 输出: John Doe
元组的类型推断
TypeScript 可以根据数组的元素自动推断出元组的类型:
let tuple = [42, "Hello"] as const; // 元组类型:[42, "Hello"]
通过 as const 断言,TypeScript 会将该元组视为一个不可变的常量元组。
连接元组
元组可以使用数组的 concat 方法进行连接,但需要注意连接后的结果是一个普通的数组,而不是元组。
实例
let tuple2: [boolean, number] = [true, 100];
let result = tuple1.concat(tuple2); // 结果是一个数组: [42, "Hello", true, 100]
console.log(result); // 输出: [42, "Hello", true, 100]
切片元组
你可以使用数组的 slice 方法对元组进行切片操作,返回一个新的数组。
实例
let sliced = tuple.slice(1); // 从索引 1 开始切片
console.log(sliced); // 输出: ["Hello", true]
遍历元组
你可以使用 for...of 循环或者 forEach 方法遍历元组中的元素。
实例
// 使用 for...of 循环
for (let item of tuple) {
console.log(item);
}
// 使用 forEach 方法
tuple.forEach(item => console.log(item));
转换为普通数组
虽然元组是一个固定长度、固定类型的数组,但可以通过 Array.prototype 的方法将其转换为普通数组进行进一步处理。
实例
// 转换为数组并使用数组方法
let array = Array.from(tuple);
array.push("New Element");
console.log(array); // 输出: [42, "Hello", true, "New Element"]
扩展元组
使用剩余运算符可以轻松地将多个元组合并成一个新的元组:
实例
let tuple2: [boolean] = [true];
let extendedTuple: [number, string, ...typeof tuple2] = [42, "Hello", ...tuple2];
console.log(extendedTuple); // 输出: [42, "Hello", true]