带你读《现代TypeScript高级教程》十一、泛型和类型体操(2)https://developer.aliyun.com/article/1348496?groupCode=tech_library
b)Required
Required 是 TypeScript 中的另一个内置泛型类型,它可以将给定类型 T 中的所有可选属性转换为必需属性。这对于确保对象的完整性非常有用。
interface Person { name?: string; age?: number;} type RequiredPerson = Required; const requiredPerson: RequiredPerson = { name: 'John', age: 25 }; // name 和 age 属性是必需的
在上面的示例中,Required 将 Person 接口中的所有可选属性变为必需属性,从而创建了一个要求完整性的 RequiredPerson 类型。
c)Pick
Pick 是 TypeScript 中的另一个内置泛型函数,它可以从给定类型 T 中选择指定的属性 K 组成一个新的类型。
interface Person { name: string; age: number; address: string;} type NameAndAge = Pick; const person: NameAndAge = { name: 'John', age: 25 }; // 只包含 name 和 age 属性
在上面的示例中,Pick 从 Person 接口中选择了 'name' 和 'age' 属性,创建了一个新的类型 NameAndAge。
我们还可以结合泛型和内置泛型函数来实现更复杂的类型操作。以下是一个示例,展示了如何使用 Pick 和泛型来创建一个函数,该函数从给定对象中选择指定属性,并返回一个新的对象。
function pickProperties(obj: T, keys: K[]): Pick { const result: Partial = {}; for (const key of keys) { result[key] = obj[key]; } return result as Pick;} interface Person { name: string; age: number; address: string;} const person: Person = { name: 'John', age: 25, address: '123 Main St'}; const nameAndAge = pickProperties(person, ['name', 'age']); // 只包含 name 和 age 属性console.log(nameAndAge); // 输出: { name: 'John', age: 25 }
在上面的示例中,pickProperties 函数接受一个泛型参数 T 和一个属性数组 keys。通过使用 Pick,我们将从给定对象 obj 中选择指定的属性 keys,并创建一个新的对象。
这个例子结合了泛型、内置泛型函数 Pick、keyof 操作符和 extends 关键字,展示了如何在 TypeScript 中处理复杂的类型操作和转换。
当涉及到官方内置的泛型函数时,还有一些重要的函数值得分析。让我们继续探讨一些常用的官方内置泛型函数以及它们的使用。
- Exclude
Exclude 是 TypeScript 中的一个内置泛型函数,用于从类型 T 中排除类型 U。它返回一个新类型,该新类型包含在 T 中存在但不在 U 中存在的成员类型。
type T = Exclude<"a" | "b" | "c", "a" | "b">; // T 的类型为 "c"
在上面的示例中,Exclude<"a" | "b" | "c", "a" | "b"> 排除了类型 "a" 和 "b",返回类型为 "c"。
带你读《现代TypeScript高级教程》十一、泛型和类型体操(4)https://developer.aliyun.com/article/1348494?groupCode=tech_library