当前位置: 首页 > news >正文

TypeScript 元组类型精简知识点

一、元组基础特性

  • 定义:TypeScript 特有类型,允许数组成员类型不同(与数组的“同类型成员”特征区分)。
  • 声明方式:成员类型写在方括号内,需显式声明(否则会被推断为联合类型数组)。
    示例:const t: [string, number, boolean] = ['a', 1, true]
  • 与数组的区分
    • 数组:类型写在方括号外(number[]),成员类型必须相同。
    • 元组:类型写在方括号内([number]),成员类型可不同。

二、元组成员规则

  • 可选成员:尾部成员可加 ? 表示可选(可选成员必须在必选成员之后)。
    示例:type Tuple = [number, string?](可包含 1 或 2 个成员)。
  • 不定成员:用扩展运算符(...)表示不限数量的成员,... 后需跟数组/元组。
    示例:type NamedNums = [string, ...number[]](第一个成员为字符串,后续为任意数量数值)。
    • ... 可位于元组任意位置(头部、中部、尾部)。
  • 成员命名:可添加说明性名称(无实际作用),格式为 名称: 类型
    示例:type Color = [red: number, green: number, blue: number]

三、只读元组

  • 声明方式
    1. readonly [类型1, 类型2]
    2. Readonly<[类型1, 类型2]>(泛型工具类型)。
  • 特性:禁止修改、新增、删除成员。
  • 类型关系:普通元组是只读元组的子类型(普通元组可赋值给只读元组,反之不行)。
    • 示例:let t: [number] = [1]; let rt: readonly [number] = t 正确;t = rt 报错。

四、成员类型与数量推断

  • 成员类型读取
    • 通过索引:type Tuple = [string, number]; type T = Tuple[1](返回 number)。
    • 所有成员类型:Tuple[number](返回联合类型,如 string|number)。
  • 成员数量推断
    • 无可选成员和 ... 时,TypeScript 可确定元组长度(如 [number, number] 长度固定为 2)。
    • 含可选成员时,推断可能的长度范围(如 [number, number?] 长度为 1|2)。
    • ... 时,无法推断长度,元组会被当作数组处理(成员数量不确定)。

五、扩展运算符应用

  • 数组传参问题:数组用 ... 传参时,因成员数量不确定可能报错(如函数需固定参数个数)。
  • 解决方法
    1. 将数组声明为固定长度元组:const arr: [number, number] = [1, 2]
    2. 使用 as const 断言:const arr = [1, 2] as const(推断为只读元组 readonly [1, 2])。
http://www.lryc.cn/news/611741.html

相关文章:

  • 大数据存储域——HDFS存储系统
  • MCP协议与Spring AI框架实战
  • NY112NY117美光固态闪存NY119NY123
  • 新手向:Python实现简易计算器
  • 疯狂星期四文案网第30天运营日记
  • mysql索引的用法
  • Suno API V5模型 python源码 —— 使用灵感模式进行出创作
  • 国产3D大型装配设计新突破①:图纸打开设计双加速 | 中望3D 2026
  • rsync 的三种常见用法
  • 学习bug
  • jmm 指令重排 缓存可见性 Volatile 内存屏障
  • word2vector细致分解(CBOW, SKIP_GRAM, 层次soft Max, 负采样)
  • linux创建虚拟内存
  • Linux Vim 常用快捷键
  • Java学习第一百一十部分——CI/CD
  • 【完整源码+数据集+部署教程】爬行动物异常检测系统源码和数据集:改进yolo11-GhostDynamicConv
  • 一个php 连sqlserver 目标计算机积极拒绝,无法连接问题的解决
  • CVE-2021-30661、CVE-2021-30665、CVE-2021-30666
  • 浅谈对linux进程池的理解
  • back_inserter 详解
  • 快手小店客服自动化回复
  • 基于 Jenkins Pipeline 实现 DITA 文档自动化构建与发布(开源方案)
  • 基于模式识别的订单簿大单自动化处理系统
  • 【Redis】hash哈希,List列表
  • 在Jetson AGX Orin上将docker目录挂载到大容量硬盘目录
  • 【C语言】文件操作全解析
  • c++ template in .h and .cpp
  • 快速删除 `node_modules`
  • 2025面试题(10)
  • Shader开发(八)创建第一个三角形