【问题标题】:TypeScript: Getting the type of the property at keyof TTypeScript:在 keyof T 处获取属性的类型
【发布时间】:2021-11-13 18:30:49
【问题描述】:

我在玩 TypeScript 及其打字系统时获得了一些乐趣 - 这并不重要,但也许你们中的一些人会发现这和我一样有趣或有趣。

由于我经常发现自己按所述对象的属性对数组进行排序,所以我想,“为什么不实现 sortBy 函数?”。

Array.prototype.sortBy = function <T, P extends keyof T>(
  this: T[],
  compareFn: (a: unknown, b: unknown) => number,
  key: P
): T[] {
  return this.sort((a, b) => compareFn(a[key], b[key]));
};

用法:

interface A {
  keyA: string;
  keyB: number;
}
const arr: A[] = [
  { keyA: "a", keyB: 42 },
  { keyA: "b", keyB: 1337 },
  { keyA: "c", keyB: -1 },
];
arr.sortBy((a: number, b: number) => b - a, "keyB");

这个实现是可行的,我认为这很酷,甚至可以将键列表作为类型变量 - 据我所知,例如在 C# 中这种行为是不可能的。

我还想清理最后一件事 - 比较器的 unknown 类型。编译器无法在运行时之前捕获任何可能很危险的错误。是否可以告诉 TS“T 中的属性 P 的类型”?

我想像K extends typeof P in TK extends typeof T[P] 这样的东西。

如果可能的话,我什至可以在函数声明中添加子键,以便按对象树更深处的属性进行搜索。

PS:我知道这是一个相当人为的问题,而且我认为K extends typeof T[P] 在很多情况下根本没有用处。但是玩代码并进行讨论非常有趣,并且加深了对相关语言的理解。

【问题讨论】:

    标签: typescript generics types syntactic-sugar


    【解决方案1】:

    您所要做的就是引用键值:T[P] 请参阅:

    Array.prototype.sortBy = function <T, P extends keyof T>(
      this: T[],
      compareFn: (a: T[P], b: T[P]) => number,
      key: P
    ): T[] {
      return this.sort((a, b) => compareFn(a[key], b[key]));
    };
    

    Playground

    【讨论】:

    • 哇,我没想到这是可能的!非常感谢!所以我走在了正确的轨道上——我只是没想到我不必创建另一个泛型类型变量^^
    猜你喜欢
    • 2021-07-19
    • 2018-02-04
    • 2021-08-26
    • 2022-08-11
    • 2023-04-07
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多