TypeScript 中如何使用 keyof 关键字?
在 TypeScript 中,keyof 关键字在处理对象及其属性时起着重要作用。它允许我们获取对象的键并使用它们执行各种操作。本教程将指导您了解 keyof 的用法,提供不同场景下的语法解释和代码示例。
语法
keyof Type
以上是 TypeScript 中 keyof 关键字的语法。keyof 关键字后跟类型名称,称为“Type”。它返回一个联合类型,其中包含指定类型的所有键(属性名称)。这使我们能够动态访问和操作对象的键。
示例 1:访问对象属性名称
keyof 关键字帮助我们检索在对象类型中定义的属性的名称。在本例中,我们定义了一个名为“Person”的接口,它有两个属性:“name”类型为字符串,“age”类型为数字。然后,我们使用 keyof 创建一个类型别名“PersonKeys”来从 Person 接口中提取键。最后,我们将值“name”分配给名为“keys”的常量,该常量的类型为 PersonKeys,并记录其值。
interface Person {
name: string;
age: number;
}
type PersonKeys = keyof Person;
const keys: PersonKeys = 'name';
console.log(keys);
编译后,它将生成以下 JavaScript 代码:
var keys = 'name'; console.log(keys);
输出
以上代码将产生以下输出:
name
示例 2:类型安全的属性访问
keyof 关键字使我们能够以类型安全的方式访问对象属性。在这里,我们定义了一个名为“Car”的接口,其属性表示汽车的品牌、年份和价格。我们声明了一个名为“getProperty”的泛型函数,它接受两个参数:“obj”类型为 T,“key”类型为 K,其中 K 扩展 keyof T。该函数返回对象中给定键对应的值。然后,我们创建一个汽车对象并使用“getProperty”函数检索汽车的品牌属性并将其分配给“carBrand”变量。最后,我们记录“carBrand”的值。
interface Car {
brand: string;
year: number;
price: number;
}
function getProperty<T, K extends keyof T>(obj: T, key: K): T[K] {
return obj[key];
}
const car: Car = {
brand: 'Toyota',
year: 2022,
price: 25000,
};
const carBrand: string = getProperty(car, 'brand');
console.log(carBrand);
编译后,它将生成以下 JavaScript 代码:
function getProperty(obj, key) {
return obj[key];
}
var car = {
brand: 'Toyota',
year: 2022,
price: 25000
};
var carBrand = getProperty(car, 'brand');
console.log(carBrand);
输出
以上代码将产生以下输出:
Toyota
示例 3:映射对象属性
keyof 关键字也可用于将属性从一个对象映射到另一个对象。在本例中,我们定义了一个名为“Fruit”的接口,其属性表示水果的名称和颜色。然后,我们使用映射类型中的 keyof 创建一个新的类型“FruitMapped”。它将 keyof Fruit 中的每个键映射到“string”类型。最后,我们使用 FruitMapped 类型创建一个“fruit”对象并记录其值。
interface Fruit {
name: string;
color: string;
}
type FruitMapped = {
[K in keyof Fruit]: string;
};
const fruit: FruitMapped = {
name: 'Apple',
color: 'Red',
};
console.log(fruit);
编译后,它将生成以下 JavaScript 代码:
var fruit = {
name: 'Apple',
color: 'Red'
};
console.log(fruit);
输出
以上代码将产生以下输出:
{ name: 'Apple', color: 'Red' }
示例 4:条件类型映射
keyof 关键字的另一个强大应用是在条件类型映射中。这使我们能够根据某些条件选择性地映射属性。在本例中,我们有一个名为“Product”的接口,它表示产品的名称、价格和可用性。我们定义了一个名为“DiscountedProducts”的类型,它使用 keyof 进行条件映射。它检查属性的值是否扩展“number”类型,并将其映射到原始值和“null”的联合类型。对于所有其他属性类型,它保持原始值类型不变。最后,我们使用 DiscountedProducts 类型创建一个“product”对象。
interface Product {
name: string;
price: number;
inStock: boolean;
}
type DiscountedProducts<T> = {
[K in keyof T]: T[K] extends number ? T[K] | null : T[K];
};
const product: DiscountedProducts<Product> = {
name: 'Widget',
price: 10,
inStock: true,
};
console.log(product);
编译后,它将生成以下 JavaScript 代码:
var product = {
name: 'Widget',
price: 10,
inStock: true
};
console.log(product);
输出
以上代码将产生以下输出:
{ name: 'Widget', price: 10, inStock: true }
结论
在本教程中,我们探讨了 TypeScript 中的 keyof 关键字,它使我们能够更有效、更安全地处理对象属性。我们涵盖了诸如访问对象属性名称、类型安全的属性访问、映射对象属性、条件类型映射以及强制执行对象键子集等场景。通过理解和使用 keyof,您可以编写更健壮、更易于维护的 TypeScript 代码。
keyof 关键字使开发人员能够在类型级别提取、操作和强制执行对象的结构。它增强了类型安全性并允许强大的抽象。将 keyof 集成到您的 TypeScript 项目中以释放其潜力并简化您的开发流程。
数据结构
网络
关系数据库管理系统
操作系统
Java
iOS
HTML
CSS
Android
Python
C 语言编程
C++
C#
MongoDB
MySQL
Javascript
PHP