简单写法

const data = {
  a: 3,
  hello: 'world'
}

function get(o: object, name: string) {
  return o[name]
}

但这样写有两个问题

1、无法确认返回类型:这将损失 ts 最大的类型校验功能

2、无法对 key 做约束:可能会犯拼写错误的问题

 

升级版

function get<T extends object, K extends keyof T>(o: T, name: K): T[K] {
  return o[name]
}

如何理解 K extends keyof T ?

假设T为{a:number,b:number},keyof T则为'a'|'b'(联合类型),那么K继承自'a'|'b',则可为'a'、'b'或'a'|'b'
一般使用的时候无需表面T为多少,K为多少,借由自动的类型推论就可知晓,例:
get(data, 'a')

相关文章:

  • 2021-06-19
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
猜你喜欢
  • 2022-12-23
  • 2022-12-23
  • 2021-06-08
  • 2022-12-23
  • 2022-12-23
  • 2021-07-11
  • 2022-01-24
相关资源
相似解决方案