操作符keyof的作用是什么

keyof 是 TypeScript 中的一个操作符,它用于获取一个类型的所有属性名(键)组成的联合类型。

使用 keyof 操作符可以在编译时获得一个类型的属性名,然后将这些属性名作为联合类型进行处理或操作。它可以用于访问对象的属性,定义映射类型,以及进行类型约束等场景。

下面是一些示例来说明 keyof 的作用:

  1. 访问对象的属性:
复制代码
  interface Person {
      name: string;
      age: number;
  }

  const person: Person = {
      name: "Alice",
      age: 25,
  };

  type PersonKeys = keyof Person; // 联合类型:"name" | "age"

  console.log(person["name"]); // 访问对象属性

在上述示例中,PersonKeys 类型通过 keyof Person 获取了 Person 接口的属性名,即 "name""age",作为联合类型。

  • 定义映射类型:

复制代码
  interface Person {
      name: string;
      age: number;
  }

  type ReadonlyPerson = {
      readonly [K in keyof Person]: Person[K];
  };

  const readonlyPerson: ReadonlyPerson = {
      name: "Alice",
      age: 25,
  };

  readonlyPerson.name = "Bob"; // 错误,只读属性无法修改

在上述示例中,通过使用 keyof Person,我们创建了一个映射类型 ReadonlyPerson,将 Person 接口的所有属性都设置为只读。

  • 进行类型约束:
复制代码
   function getProperty<T, K extends keyof T>(obj: T, key: K): T[K] {
       return obj[key];
   }

   const person: Person = {
       name: "Alice",
       age: 25,
   };

   const name = getProperty(person, "name"); // name 的类型为 string
   const age = getProperty(person, "age"); // age 的类型为 number
   const invalid = getProperty(person, "email"); // 错误,"email" 不是 Person 的属性名

在上述示例中,getProperty 函数使用了两个泛型参数 TK extends keyof T。通过使用 keyof T,我们对第二个参数 key 进行了类型约束,确保它必须是 T 类型的属性名。

总结起来,keyof 操作符在 TypeScript 中用于获取一个类型的所有属性名组成的联合类型。它可以用于访问对象的属性,定义映射类型以及进行类型约束等场景,提供了更灵活和安全的类型操作。

相关推荐
Yvonne爱编码37 分钟前
CSS- 1.1 css选择器
前端·css·状态模式·html5·hbuilder
山河故人1631 小时前
uniapp使用npm下载
前端·npm·uni-app
-曾牛1 小时前
基于微信小程序的在线聊天功能实现:WebSocket通信实战
前端·后端·websocket·网络协议·微信小程序·小程序·notepad++
一口一个橘子2 小时前
[ctfshow web入门] web72
前端·web安全·网络安全
Web极客码2 小时前
如何使用WordPress SEO检查器进行实时内容分析
前端·seo·wordpress
Stella25212 小时前
【Vue】CSS3实现关键帧动画
前端·vue.js·css3
junjun.chen06062 小时前
【在qiankun模式下el-dropdown点击,浏览器报Failed to execute ‘getComputedStyle‘ on ‘Window‘: parameter 1 is not o
前端·javascript·前端框架
Yvonne爱编码2 小时前
HTML-3.3 表格布局(学校官网简易布局实例)
前端·html·github·html5·hbuilder
jllllyuz3 小时前
matlab实现蚁群算法解决公交车路径规划问题
服务器·前端·数据库
小屁孩大帅-杨一凡3 小时前
一个简单点的js的h5页面实现地铁快跑的小游戏
开发语言·前端·javascript·css·html