ts实现.get

Posted yanze

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了ts实现.get相关的知识,希望对你有一定的参考价值。

简单写法

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‘|...,也可为string
一般使用的时候无需表面T为多少,K为多少,借由自动的类型推论就可知晓,例:
get(data, ‘a‘)

以上是关于ts实现.get的主要内容,如果未能解决你的问题,请参考以下文章

替换从 VAST 代码返回的多个 HLS VOD 片段

ASP.net MVC 代码片段问题中的 Jqgrid 实现

已解决在react+ts中 atnd 用 upload 组件报错Failed to execute ‘readAsArrayBuffer,param 1 is notof type Blob(代码片段

已解决在react+ts中 atnd 用 upload 组件报错Failed to execute ‘readAsArrayBuffer,param 1 is notof type Blob(代码片段

python小白学习记录 多线程爬取ts片段

Python snippet(代码片段)