索引签名

索引签名

在js中ES6允许用表达式作为对象的属性名,但是一定要将表达式放在方括号内。会把表达式使用toString()方法,这样js中对象和函数等也可以作为索引。而ts 做了进一步的约束,索引类型只能是:string | number | symbol,而value 可以是任意类型

索引签名的名称如[index:number]:string里的index只是占位符并无任何意义,可以是任意单词。

索引签名就是在约束了索引(key)类型的基础上,统一定义了对象的 keyvalue 的类型 。换句话说,索引签名可以在只知道keyvalue 的类型下,来统一定义对象的类型

当声明一个索引签名后,所有成员的key和value都必须符合索引签名

js 复制代码
interface Sign1 {
  // key 只是占位符
  [key: string]: string;
}

type Sign2 = {
  [index: number]: string | number;
};

const foo: {
  [aaa: string]: { message: string }; // value 只能是1个对象,并且只有1个属性 message
} = {};

定义了索引签名,那么确定属性和可选属性的类型都必须是它的类型的子集

js 复制代码
type attentionType{
    name: string; // 编译通过
    age?: number; // 编译报错:类型"number | undefined"的属性"age"不能赋给"string"索引类型"string"。ts(2411)
    sex?: undefined; // 编译通过
    [propName: string]: string | undefined;
}

在多个索引签名存在时,string 类型的索引最严格,书写时应该包含所有的 value 类型。其他类型的索引,对应的 value 类型只能是string 类型的value类型的子级

js 复制代码
interface Sign3 { 
    [key: string]: string | number | boolean;// 必须包括所用成员类型
    [index: symbol]: string; 
    [index2: number]: number; 
}
js 复制代码
interface Animal {
  name: string;
}
interface Dog extends Animal {
  breed: string;
}

interface NotOkay {
  [x: string]: Dog;
  [x: number]: Animal; // Error
}

interface Okay {
  [x: string]: Animal;
  [x: number]: Dog; // OK
}
相关推荐
鼎道开发者联盟11 小时前
鼎享会 | OpenClaw Control UI 前端架构全解析:自研 UI 对接 Server 实操指南
前端·ui·架构·openclaw·control ui
尘世中一位迷途小书童11 小时前
一套完整的给予ceium封装的组件库,可满足企业级开发
前端
Z_Wonderful11 小时前
微前端:Webpack 配置 vs Vite 配置 超清晰对比
前端·webpack·node.js
码云数智-园园11 小时前
HTTPS是如何工作的?从HTTP到HTTPS的加密演进
前端
隔窗听雨眠11 小时前
HTML头部元信息避坑指南
前端·html
Gauss松鼠会12 小时前
【openGauss】openGauss 磁盘引擎之 ustore
java·服务器·开发语言·前端·数据库·经验分享·gaussdb
LIO12 小时前
前端响应式页面开发全攻略:核心技术 + 实现效果 + 实战指南
前端·响应式设计
得物技术12 小时前
AI驱动:从运营行为到自动化用例的智能化实践|得物技术
前端·ai编程·全栈
前端那点事12 小时前
Vue并发控制|几十个请求高效管控(实战方案+可运行代码)
前端·vue.js
妄想出头的工业炼药师12 小时前
后端优化MS mapping
前端