TypeScript keyof 关键字

本文介绍了TypeScript中的keyof关键字,它用于从对象类型中提取键类型。通过keyof,我们可以创建一个属性的联合类型,并在函数参数中使用。例如,在带有显式键的接口Person上,keyofPerson生成了'name'和'age'的联合类型。此外,当keyof与索引签名结合时,它可以提取索引类型,如在StringMap类型中,keyofStringMap解析为'string'。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

keyof 是 TypeScript 中的关键字,用于从对象类型中提取键类型。

带有显式键的 keyof

在具有显式键的对象类型上使用时,keyof 会使用这些键创建联合类型。

interface Person {
  name: string
  age: number
}

// keyof Person 在这里创建一个 name 和 age 的联合类型,不允许使用其他字符串
function printName(person: Person, property: keyof Person) {
  console.log(`打印 person 属性 ${property}: '${person[property]}'`)
}

let person = {
  name: 'O.O',
  age: 18
}

printName(person, 'name') // 'O.O'

带索引签名的 keyof

keyof 还可以与索引签名一起使用,以提取索引类型。

type StringMap = {
  [key: string]: unknown
}

// 这里的 keyof StringMap 解析为 string
function foo(property: keyof StringMap, value: string): StringMap {
  return {
    [property]: value
  }
}

foo('name', 'O.O') // { name: 'O.O' }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值