TypeScript3(数组)

1.写法1:类型[]

这是最常用、最直观的定义方式,表示一个由特定类型元素组成的数组。

ts 复制代码
const arr1: number[] = [1, 2, 3];
const arr2: string[] = ['a', 'b', 'c'];
const arr3: boolean[] = [true, false];
const arr4: any[] = [1, 'a', true];

arr1.unshift(0); // [0, 1, 2, 3]

联合类型数组:如果数组中的元素类型不确定,可以使用联合类型。

ts 复制代码
// 数组元素可以是 number 或 string 
let mixedArray: (number | string)[] = [1, 'two', 3, 'four'];

2.写法2:泛型数组Array<类型>

这种语法使用泛型(Generics)来定义数组类型,提供了另一种可读性强的选择。

ts 复制代码
let numbers: Array<number> = [1, 2, 3, 4];

同样也可以使用联合类型

ts 复制代码
let mixedArray: Array<number | string> = [1, 'two', 3, 'four'];

3.用接口表示数组

一般用来描述类数组,核心在于描述那些结构不完全是数组,但行为又类似数组的复杂对象。

ts 复制代码
interface NumberArray {
    // 可以描述任何拥有数字索引并且值是数字的对象
    [index: number]: number;
}
const arr6: NumberArray = [1, 2, 3];

举个栗子

ts 复制代码
interface StudentScore {
    [index: number]: number;
    name: string;
    average(): number;
}

const score: StudentScore = {
    0: 90,
    1: 95,
    2: 100,
    name: "YaeZed",
    average() {
        let sum = 0;
        for (let i = 0; i < 3; i++) {
            // sum += this[i];// 这里报错原因是因为编译器无法保证每个i都存在
            const score = this[i];
            if (score !== undefined) sum += score; // 这里的undefined判断是为了避免数组越界
        }
        return sum / 3;
    }
}
// console.log(score[0]);
// console.log(score.name);
// console.log(score.average());

4.any

any类型数组,在 TypeScript 中,any[] 是一种特殊的数组类型,它允许数组中包含任何类型的元素。它本质上是 TypeScript 类型的"逃生舱",用于在类型系统无法确定或不方便确定类型时,暂时放弃类型检查。更多还是使用联合类型。

ts 复制代码
const arr7: any[] = [1, 'a', true];

参考文章

小满zs 学习typeScript4(数组类型) xiaoman.blog.csdn.net/article/det...

相关推荐
VT.馒头10 小时前
【力扣】2625. 扁平化嵌套数组
前端·javascript·算法·leetcode·职场和发展·typescript
San30.12 小时前
从零构建坚固的前端堡垒:TypeScript 与 React 实战深度指南
前端·react.js·typescript
VT.馒头14 小时前
【力扣】2694. 事件发射器
前端·javascript·算法·leetcode·职场和发展·typescript
止观止16 小时前
像三元表达式一样写类型?深入理解 TS 条件类型与 `infer` 推断
前端·typescript
We་ct16 小时前
LeetCode 73. 矩阵置零:原地算法实现与优化解析
前端·算法·leetcode·矩阵·typescript
We་ct17 小时前
LeetCode 48. 旋转图像:原地旋转最优解法
前端·算法·leetcode·typescript
We་ct1 天前
LeetCode 54. 螺旋矩阵:两种解法吃透顺时针遍历逻辑
前端·算法·leetcode·矩阵·typescript
We་ct1 天前
LeetCode 36. 有效的数独:Set实现哈希表最优解
前端·算法·leetcode·typescript·散列表
Async Cipher2 天前
TypeScript 的用法
前端·typescript
We་ct2 天前
LeetCode 30. 串联所有单词的子串:从暴力到高效,滑动窗口优化详解
前端·算法·leetcode·typescript