keyof和in和typeof

keyof

keyof后面跟接口,表示遍历接口的这些的属性名(实际上一个键值对就是冒号前面的这些)。keyof表示索引查询,可以用于获取接口类型的所有键,其返回类型是联合类型。

js 复制代码
interface People {
  name:string;
  age:number;
}
// type类型别名:pType的类型表示"name"|"age"
// 键名以字符串形式存储,所以遍历出的接口属性名都是字符串,就是常量
type pType = keyof People;
// 编译报错,p1的值只能是字符串name和age
let p1:pType = 2
let p2:pType = "xxx"

当需要type pType = keyof People;的类型也可以是其他字符串的做法如下:

js 复制代码
interface People {
  name:string;
  age:number;
  // 表示属性名是数字number类型,遍历后是变量number
  [idx:number]:number|string;
  // 表示属性名是字符串string类型,遍历后是变量string
  [idx:string]:number|string;
}
// 类型别名:pType的类型表示"name"|"age"|number|string
type pType = keyof People;
let p1:pType = 6;
let p2:pType = "xxx"

in

in用于取联合类型的值。主要用于数组和对象的构造。

js 复制代码
type name = 'firstName' | 'lastName';
type TName = {
  [key in name]: string;
};

typeof

TS中,typeof操作符可以用来获取一个变量或对象的类型。

js 复制代码
// 提取变量
let str = "267";
type StrType = typeof str; // string
// 编译报错
let a:StrType = 267;
// 提取对象 (包含对象的所有属性且属性值类型要一样)
let obj = {
  name: 530,
  age: "418",
  height: 816
}
type withJ = typeof obj;
// 编译报错
let obj1:withJ ={
  
}
// 编译报错
let obj2:withJ = {
  width:267
}
相关推荐
Bug-制造者9 分钟前
【Vue3 实战】全局错误处理体系搭建:实现业务与错误彻底解耦
前端·javascript·vue.js
悟空瞎说12 分钟前
# Git 交互式变基:优雅整理提交历史,告别杂乱 PR 记录
前端·git
还有多久拿退休金25 分钟前
DragSortTable:一个让我怀疑人生的滚动重置 Bug
前端
渐儿28 分钟前
组件库开发入门到生产(从零封装到 npm 发布)
前端
KaMeidebaby1 小时前
卡梅德生物技术快报|单 B 细胞抗体制备:流程优化、表达系统适配与性能数据
前端·数据库·其他·百度·新浪微博
lichenyang4531 小时前
从鸿蒙 AI 聊天 Demo 学习 ArkUI V2:第一天上手记录
前端
进击的松鼠1 小时前
OpenClaw 的五层架构设计与解析
前端·架构·agent
JavaGuide1 小时前
Claude Code 新功能Agent View 发布:终于不用在一堆终端窗口里找 Agent 了!
前端·后端·agent
不简说2 小时前
前端可视化打印设计器sv-print,一口气更新了30版
前端·源码·产品
颖火虫盟主2 小时前
Claude Code Hook 系统详解与 Hello World 实操
前端·网络·数据库