数组和元祖
# 数组
# 类型 + 方括号
let fibonacci: number[] = [1, 1, 2, 3, 5];
1
数组的项中不允许出现其他的类型:
let fibonacci: number[] = [1, '1', 2, 3, 5];
// Type 'string' is not assignable to type 'number'.
1
2
3
2
3
提示
和Java一样,数组一旦声明,里面只可以传入一个,指定类型的值
# 用接口表示数组
接口也可以用来描述数组:
interface NumberArray {
[index: number]: number;
}
let fibonacci: NumberArray = [1, 1, 2, 3, 5];
1
2
3
4
2
3
4
NumberArray
表示:只要索引的类型是数字时,那么值的类型必须是数字。
# 类数组
类数组并不是数组类型,只是一个像类的数组,不能用普通的数组的方式来描述,描述类应该用接口,所以描述类数组也应该用接口。
比如IArguments
, NodeList
, HTMLCollection
,等JavaScript的内置对象,看起来像数组,可是并不是数组。
# any 在数组中的应用
用 any
表示数组中允许出现任意类型,就回到了JavaScript的数组。
# 元组
数组合并了相同类型的对象,而元组(Tuple)合并了不同类型的对象。
元组起源于函数编程语言(如 F#),这些语言中会频繁使用元组。
# 例子
定义一对值分别为 string
和 number
的元组:
let tom: [string, number] = ['Tom', 25];
1
当赋值或访问一个已知索引的元素时,会得到正确的类型:
let tom: [string, number];
tom[0] = 'Tom';
tom[1] = 25;
tom[0].slice(1);
tom[1].toFixed(2);
1
2
3
4
5
6
2
3
4
5
6
也可以只赋值其中一项:
let tom: [string, number];
tom[0] = 'Tom';
1
2
2
但是当直接对元组类型的变量进行初始化或者赋值的时候,需要提供所有元组类型中指定的项。
let tom: [string, number];
tom = ['Tom', 25];
let tom: [string, number];
tom = ['Tom'];
// Property '1' is missing in type '[string]' but required in type '[string, number]'.
1
2
3
4
5
6
2
3
4
5
6
# 越界的元素
当添加越界的元素时,它的类型会被限制为元组中每个类型的联合类型:
let tom: [string, number];
tom = ['Tom', 25];
tom.push('male');
tom.push(true);
// Argument of type 'true' is not assignable to parameter of type 'string | number'.
1
2
3
4
5
6
2
3
4
5
6
上次更新: 2022/05/12 14:57:53