keyof和infer

keyof

keyof是ts中的操作符,用于获取一个类型的所有键名组成的联合类型,在处理对象类型和泛型时特别有用。

1、比如一个函数,第一个参数接收对象,第二个参数需要是前面对象的属性名,这时要约束第二个参数就能用keyof了,下面是代码示例:

TypeScript 复制代码
function getProperty<T, K extends keyof T>(obj: T, key: K): T[K] {
  return obj[key];
}

const person: Person = {
  name: "张三",
  age: 30,
  address: "北京"
};

const name = getProperty(person, "name"); // 类型为 string
const age = getProperty(person, "age");   // 类型为 number
getProperty(person, "job");  // 错误:参数"job"不能赋给类型"keyof Person"的参数

infer

infer用于条件类型中进行占位,我们可以用来提取函数的返回类型

1、提取函数返回类型。

定义类型ReturnType,infer R表示函数类型的返回值,泛型满足函数类型的条件时ReturnType的类型就是函数返回值的类型,代码示例如下:

TypeScript 复制代码
type ReturnType<T> = T extends (...args: any[]) => infer R ? R : any;

function greet(): string {
    return "Hello, World!";
}

type GreetReturn = ReturnType<typeof greet>; // string

END

相关推荐
yijianace19 小时前
Python爬虫实战:分页爬取 + 详情页采集 + CSV存储
前端·爬虫·python
想吃火锅100519 小时前
【前端手撕】防抖节流
前端
MemoriKu19 小时前
Flutter 相册 APP 视频模态稳定化实战:从视频抽帧、Embedding 元数据到 Android 真机启动修复
android·开发语言·前端·flutter·架构·音视频·embedding
lichenyang45319 小时前
ArkUI 票根卡片:PathShape 真挖洞,shadow 沿凹陷外发光
前端
Cache技术分享19 小时前
432. Java 日期时间 API - 时间工具 TemporalQuery 详解
前端·后端
假如让我当三天老蒯20 小时前
暂时性死区是否和闭包是相背的呢(自学用)
前端·javascript
渣波20 小时前
前端开发主页面小技巧
前端·javascript
柯克七七20 小时前
我用3个周末重构了公司的前端项目,老板没发现,但同事都来找我要代码了
前端
bonechips20 小时前
JS:同步与异步,从单线程到 Promise 的编程之路
前端·javascript
如果超人不会飞20 小时前
TinyVue Pager分页组件使用指南
前端·vue.js