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