对于任何类型T
,keyof T
是 的已知公共属性名称的并集T
。
例子:
interface Person {
age: number;
name: string;
}
type PersonKeys = keyof Person; // "age" | "name"
keyof string
因此,您对产量的假设startsWith | endsWith | trim | ...
是正确的。您可以在查找类型发行说明中了解有关它的更多信息。
扩展键
extends
,在这种情况下,用于约束泛型参数的类型。例子:
<T, K extends keyof T>
K
因此只能是 的公共属性名称T
。与扩展接口相反,它与扩展类型或继承无关。
的用法extends keyof
可能如下:
function getProperty<T, K extends keyof T>(obj: T, key: K): T[K] {
return obj[key];
}
const person: Person = {
age: 22,
name: "Tobias",
};
// name is a property of person
// --> no error
const name = getProperty(person, "name");
// gender is not a property of person
// --> error
const gender = getProperty(person, "gender");
除了关于索引类型的文档之外,我还发现了这篇很有帮助的文章。
在键中
in
当我们定义要使用字符串、数字或符号文字的并集键入的索引签名时使用。结合keyof
我们可以使用它来创建一个所谓的映射类型,它重新映射原始类型的所有属性。
的用法in keyof
可能如下:
type Optional<T> = {
[K in keyof T]?: T[K]
};
const person: Optional<Person> = {
name: "Tobias"
// notice how I do not have to specify an age,
// since age's type is now mapped from 'number' to 'number?'
// and therefore becomes optional
};
除了有关映射类型的文档之外,我再次发现这篇很有帮助的文章。
有趣的事实:Optional<T>
我们刚刚构建的类型与官方实用程序类型具有相同的签名Partial<T>
!