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的主要内容,如果未能解决你的问题,请参考以下文章
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(代码片段