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

相关推荐
皮皮大人9 小时前
Vue 3 响应式内核完全解密:reactive & effect 与 Vue 2 Watcher 史诗对决
前端·vue.js
LaughingZhu9 小时前
Product Hunt 每日热榜 | 2026-05-31
前端·人工智能·经验分享·搜索引擎·chatgpt·html
陆枫Larry9 小时前
CSS 中「深色 + 不透明度」vs 直接设浅色的区别
前端
Din9 小时前
使用AI从 27 秒到秒开:一次 Web 首屏加载优化实战
前端
leafyyuki9 小时前
两行 CSS 搞定筛选条行尾对齐,Element Plus 表单布局终极方案
前端
着迷不白9 小时前
六、Bash Shell 与进程管理
前端·chrome
A不落雨滴AI9 小时前
DKERP 客户端重构:30天从零到一的架构演进之路
前端
Xp021911039 小时前
知网研学、万方、WPS、大以论文四大排版工具横评,新用户免费排版等你领!
前端·css·html·生活·wps·论文排版
全栈技术负责人9 小时前
老项目新需求AI前端开发指南
前端·ai编程
周凡1239 小时前
AI 时代的 Web JavaScript 逆向分析实践与思考
前端·javascript·人工智能