首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

如何在属性对象上使用带有条件的typescript正确键入对象

在TypeScript中,您可以为对象属性定义条件类型

假设您有一个类型Person,您希望根据某个条件为属性添加类型:

代码语言:javascript
复制
interface Person {
  name: string;
  age: number;
  isStudent: boolean;
}

现在,您想要创建一个类型ConditionalPerson,它具有一个条件类型属性status,该属性仅当isStudenttrue时存在:

代码语言:javascript
复制
type ConditionalPerson<T extends Person> = T & (
  T['isStudent'] extends true ? { status: string } : {}
);

在这个例子中,我们使用了映射类型和条件类型。ConditionalPerson类型接受一个泛型参数T,该参数扩展了Person类型。然后,我们使用条件类型检查isStudent属性是否为true。如果是,则将status属性添加到类型中。

现在,您可以使用ConditionalPerson类型创建对象:

代码语言:javascript
复制
const student: ConditionalPerson<{ name: string; age: number; isStudent: true }> = {
  name: 'Alice',
  age: 20,
  isStudent: true,
  status: 'Freshman',
};

const nonStudent: ConditionalPerson<{ name: string; age: number; isStudent: false }> = {
  name: 'Bob',
  age: 30,
  isState: false,
};

注意,在nonStudent对象中,TypeScript不会要求status属性,因为它仅当isStudenttrue时才存在。

这就是如何在TypeScript中使用条件类型为对象属性添加类型。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • 如何在TypeScript中使用基本类型

    要在 macOS 或 Ubuntu 18.04 上安装,请按照如何在 macOS 上安装 Node.js 和创建本地开发环境或如何在 Ubuntu 18.04 上安装 Node.js 的使用 PPA 安装部分中的步骤进行操作...在本节中,我们将尝试使用 TypeScript 指定变量类型的语法。 类型是我们直接在代码中编写的额外信息。TypeScript 编译器使用这些额外信息来强制正确使用不同的值,具体取决于它们的类型。...在 TypeScript 中使用保存数组的变量的一个重要方面是大多数时候,我们必须键入它们。...当我们想键入无法确定其值的内容时,可以使用 unknown,但仍希望确保使用该值的任何代码在使用之前正确检查类型。...== "number") { year; } if 块中的变量 year 的类型将永远不会。这是因为,由于 year 被键入为数字,因此,这个 if 块的条件永远不会满足。

    3.7K10

    分享 30 道 TypeScript 相关面的面试题

    公共属性(通常称为“鉴别器”)允许我们在联合内的类型之间安全地切换,从而更轻松地使用此类对象。 12、继承在 TypeScript 中如何发挥作用?...这在您想要回退到默认值的情况下非常有用。 22、什么是映射类型,以及如何在 TypeScript 中使用它们? 答案:映射类型允许通过转换属性在现有类型的基础上创建新类型。...它们遵循一种模式,您可以在其中迭代对象类型的属性并生成新类型。常见用途包括使用 Partial 使接口的所有属性可选,或使用 Readonly 使它们只读。...答:TypeScript 的类型推断是指编译器在没有显式类型注释的情况下自动推断和分配类型的能力。虽然鼓励显式类型,但编译器会尽可能使用上下文(如变量初始化、返回语句等)来推断类型。...29、如何利用 TypeScript 中的条件类型? 答案:条件类型允许根据条件以更动态的方式表达类型。它们遵循 T 延伸 U ?

    1K30

    深入学习下 TypeScript 中的泛型

    在今天的内容中,我们将尝试 TypeScript 泛型的真实示例,并探索它们如何在函数、类型、类和接口中使用。...要在 macOS 或 Ubuntu 18.04 上安装,请按照如何在 macOS 上安装 Node.js 和创建本地开发环境或如何在 Ubuntu 18.04 上安装 Node.js 的使用 PPA 安装部分中的步骤进行操作...这显示在以下屏幕截图中: 了解如何在 TypeScript 中创建泛型后,您现在可以继续探索在特定情况下使用泛型。本教程将首先介绍如何在函数中使用泛型。...这是正确的,因为 A 确实扩展了字符串类型而 B 没有扩展字符串类型,因为它被设置为具有字符串类型的单个名称属性的对象的类型。...使用 NestedOmit 泛型,传入类型,然后列出要省略的属性的键。 请注意如何在第二个类型参数中使用点符号来标识要省略的键。然后将结果类型存储在 Result 中。

    39K30

    深入学习下 TypeScript 中的泛型

    在今天的内容中,我们将尝试 TypeScript 泛型的真实示例,并探索它们如何在函数、类型、类和接口中使用。...要在 macOS 或 Ubuntu 18.04 上安装,请按照如何在 macOS 上安装 Node.js 和创建本地开发环境或如何在 Ubuntu 18.04 上安装 Node.js 的使用 PPA 安装部分中的步骤进行操作...这显示在以下屏幕截图中:了解如何在 TypeScript 中创建泛型后,您现在可以继续探索在特定情况下使用泛型。本教程将首先介绍如何在函数中使用泛型。...这是正确的,因为 A 确实扩展了字符串类型而 B 没有扩展字符串类型,因为它被设置为具有字符串类型的单个名称属性的对象的类型。...使用 NestedOmit 泛型,传入类型,然后列出要省略的属性的键。 请注意如何在第二个类型参数中使用点符号来标识要省略的键。然后将结果类型存储在 Result 中。

    17710

    如何在 TypeScript 中使用函数

    要在 macOS 或 Ubuntu 18.04 上安装,请按照如何在 macOS 上安装 Node.js 和创建本地开发环境或如何在 Ubuntu 18.04 上安装 Node.js 的使用 PPA 安装部分中的步骤进行操作...如果使用的是适用于 Linux 的 Windows 子系统 (WSL),这也适用。 此外,我们需要在机器上安装 TypeScript 编译器 (tsc)。...为此,请参阅官方 TypeScript 网站。 如果不想在本地机器上创建 TypeScript 环境,可以使用官方的 TypeScript Playground 来跟随。.... (1016) 键入的箭头函数表达式 到目前为止,本教程已经展示了如何在 TypeScript 中键入使用 function 关键字定义的普通函数。...使用 TypeScript,我们可以创建函数重载,明确描述它们处理的不同情况,通过分别记录重载函数的每个实现来改善开发人员体验。 本节将介绍如何在 TypeScript 中使用函数重载。

    15K10

    Web前端面试敲重点知识,14个TypeScript核心基础面试题和答案

    开发的,事实上我们使用TS开发项目更易于维护。...6、TypeScript 中声明变量有哪些不同的关键字? 7、如何书写带有类型注释的函数 ? 8、如何在 TypeScript 中创建对象 ? 9、如何在 TypeScript 中指定可选属性 ?...函数是执行特定代码的代码块 函数可以有选择地接受一个或多个参数,处理它们,并有选择地返回一个值。 image.png 8、如何在 TypeScript 中创建对象 ?...它们类似于数组,有时也称为关联数组 但是,数组使用数字来索引值,而对象允许使用任何其他类型作为键 image.png 9、如何在 TypeScript 中指定可选属性 ? 通过添加 ?...对象类型可以具有零个或多个可选属性,在属性名称之后 image.png 10、说说枚举在 TypeScript 中是如何工作的 ?

    11.5K10

    WebStorm for Mac(JavaScript开发工具)中文版

    WebStorm for Mac(JavaScript开发工具)中文版使用JavaScript解构通过解构,您可以使用非常简洁的语法将数组和对象中的值解压缩到变量中。...Angular项目中的导航更容易在Angular应用程序中,您现在可以使用相关符号...弹出窗口(Ctrl-Cmd-Up / Ctrl + Alt + Home)在不同的组件文件(如TypeScript...CSS的浏览器兼容性检查要检查目标浏览器版本是否支持您使用的所有CSS属性,可以在首选项中启用新的 浏览器兼容性检查。...对CSS模块的Camel案例支持如果在项目中使用CSS模块,JavaScript文件中的类的代码完成现在将建议带有破折号的类名的驼峰版本。...您可以开始键入以过滤结果并跳转到您需要的代码。将项目另存为模板通过“ 工具”菜单中的新操作“ 另存为模板 ” ,您现在可以使用项目作为在IDE欢迎屏幕上创建新项目的基础。

    5K50

    TypeScript 4.4 RC版来了,正式版将于月底发布

    如果你想现在就尝试 TypeScript 的 RC 版,可以通过 NuGet 获取,或者使用以下 npm 命令: npm install typescript@rc TypeScript 4.4 版本中的部分主要亮点包括别名条件与判别式的控制流分析...链接:https://github.com/microsoft/TypeScript/pull/44730 符号与模板字符串模式索引签名 TypeScript 允许大家使用索引签名来描述各个属性都必须具备的特定对象...换句话说,TypeScript 不允许使用 symbol 键作为索引对象。...所以如果您使用 --strict 检查代码,此选项将自动开启。但您也可能在 TypeScript 4.4 上遇到如下错误: 类型'unknown'上不存在属性'message'。...} 精确可选属性类型 (--exactOptionalPropertyTypes) 在 JavaScript 当中,读取对象上的属性缺失会产生 undefined 值。

    2.6K20

    TS - Index Signatures

    答案是使用索引签名! 让我们找到什么是TypeScript索引签名以及何时需要它们。 1.为什么要索引签名 索引签名的思想是在您只知道键和值类型时键入未知结构的对象。...3.1不存在的财产 如果您尝试访问索引签名为{ [key: string]: string }的对象的不存在属性会发生什么? 正如预期的那样,TypeScript将值的类型推断为string。...如果您不正确映射,值类型可能会偏离实际的运行时数据类型。 为了使键入更准确,请将索引值标记为string或undefined。...这样做,TypeScript会意识到您访问的属性可能不存在: interface StringByString { [key: string]: string | undefined;...当在属性访问器中用作键时,JavaScript会将数字隐式强制转换为字符串(names[1]与names['1']相同)。TypeScript也执行这种强制。

    8910

    【TypeScript 演化史 — 第七章】映射类型和更好的字面量类型推断

    TypeScript 2.1 引入了映射类型,这是对类型系统的一个强大的补充。本质上,映射类型允许w咱们通过映射属性类型从现有类型创建新类型。根据咱们指定的规则转换现有类型的每个属性。...转换后的属性组成新的类型。 使用映射类型,可以捕获类型系统中类似 Object.freeze() 等方法的效果。冻结对象后,就不能再添加、更改或删除其中的属性。...对于希望在应用程序中冻结的每种类型的对象,咱们就必须定义一个包装器函数,该函数接受该类型的对象并返回冻结类型的对象。没有映射类型,咱们就不能以通用的方式静态地使用 Object.freeze()。...该方法返回一个新对象,该对象只包含咱们选择的属性。可以使用Pick对该行为进行构建,正如其名称所示。...更好的字面量类型推断 字符串、数字和布尔字面量类型(如:"abc",1和true)之前仅在存在显式类型注释时才被推断。从 TypeScript 2.1 开始,字面量类型总是推断为默认值。

    3.8K40

    深入理解 TypeScript 中的 Keyof 运算符,让你的代码更安全、更灵活!

    这种运算符可以用于如集合和类等对象,通过键值对来存储和检索数据。使用 map 实例对象的 object.keys() 方法,我们可以获取存储在内存中的键。...使用 KeyOf 运算符创建联合类型 在 TypeScript 中,当我们在具有显式键的对象类型上使用 keyof 运算符时,它会创建一个联合类型。...例如: 动态访问对象属性 : 使用 keyof 可以确保我们访问的属性在对象上是有效的,从而避免运行时错误。...类型安全的配置对象: 当我们处理配置对象时,可以使用 keyof 来确保配置项的名称是预定义的有效值。 通过在对象类型上使用 keyof 运算符,我们可以创建联合类型,从而确保属性访问的类型安全性。...在本文中,我们探讨了如何在 TypeScript 泛型、映射类型、显式键、索引签名、条件映射类型和实用类型中使用 keyof 运算符。

    23910

    【TypeScript 演化史 -- 7】映射类型和更好的字面量类型推断

    . ---- 为了保证的可读性,本文采用意译而非直译。 TypeScript 2.1 引入了映射类型,这是对类型系统的一个强大的补充。本质上,映射类型允许w咱们通过映射属性类型从现有类型创建新类型。...对于希望在应用程序中冻结的每种类型的对象,咱们就必须定义一个包装器函数,该函数接受该类型的对象并返回冻结类型的对象。没有映射类型,咱们就不能以通用的方式静态地使用 Object.freeze()。...该方法返回一个新对象,该对象只包含咱们选择的属性。可以使用 Pick 对该行为进行构建,正如其名称所示。...更好的字面量类型推断 字符串、数字和布尔字面量类型(如:"abc",1和true)之前仅在存在显式类型注释时才被推断。从 TypeScript 2.1 开始,字面量类型总是推断为默认值。...更好的只读属性推断 与局部 const 变量类似,带有字面量初始化的只读属性也被推断为字面量类型: class ApiClient { private readonly baseUrl = "https

    2.9K10

    掌握 TypeScript:20 个提高代码质量的最佳实践

    它们就像是对象的蓝图,概述了你将要使用的数据的结构和属性。 在 TypeScript 中,接口定义了对象的形状的约定。它指定了该类型的对象应具有的属性和方法,并且可以用作变量的类型。...这意味着,当你将一个对象分配给带有接口类型的变量时,TypeScript 会检查对象是否具有接口中指定的所有属性和方法。...此外,最好添加类型断言或类型保护,以确保变量被正确使用。尽可能缩小变量类型的范围。...相反,你可以使用更具体的类型或使用一些提供一定程度类型安全的更通用的类型,如 unknown 或 object。...R : any; type R1 = ReturnType string>; // string type R2 = ReturnType void>; // void 还可以使用条件类型来提取对象类型的属性

    4.2K30

    【TypeScript 演化史 — 第六章】对象扩展运算符和 rest 运算符及 keyof 和查找类型

    虽然 twitterHandle 变量是一个普通的字符串,但 rest 变量是一个对象,其中包含剩余两个未被解构的属性。 对象扩展属性 假设咱们希望使用 fetch() API 发出 HTTP 请求。...如果一个属性同时出现在两个对象中,则后分配的会替换前面的。 当然,TypeScript 理解这种顺序。...因此,如果多个扩展对象使用相同的键定义一个属性,那么结果对象中该属性的类型将是最后一次赋值的属性类型,因为它覆盖了先前赋值的属性: const obj1 = { prop: }; const obj2...,可以考虑使用 JSON.parse(JSON.stringify(obj)) 或其他方法,如 object.assign()。...一个对象的不同属性可以有完全不同的类型,咱们甚至不知道 obj 是什么样子的。 那么如何在 TypeScript 中编写这个函数呢?

    3.2K50

    【TypeScript 演化史 -- 6】对象扩展运算符和 rest 运算符及 keyof 和查找类型

    TypeScript 2.1 增加了对 对象扩展运算和 rest 属性提案的支持,该提案在 ES2018 中标准化。可以以类型安全的方式使用 rest 和 spread 属性。...如果一个属性同时出现在两个对象中,则后分配的会替换前面的。 当然,TypeScript 理解这种顺序。...因此,如果多个扩展对象使用相同的键定义一个属性,那么结果对象中该属性的类型将是最后一次赋值的属性类型,因为它覆盖了先前赋值的属性: const obj1 = { prop: 42 }; const obj2...,可以考虑使用 JSON.parse(JSON.stringify(obj)) 或其他方法,如 object.assign()。...一个对象的不同属性可以有完全不同的类型,咱们甚至不知道 obj 是什么样子的。 那么如何在 TypeScript 中编写这个函数呢?

    2.6K30

    如何在 TypeScript 中为对象动态添加属性?

    在本文中,我们将讨论如何在 TypeScript 中为对象动态添加属性,以及这样做的一些注意事项。...为对象动态添加属性的几种方法方法一:使用索引签名在 TypeScript 中,我们可以使用索引签名来动态添加属性到对象上。...具体来说,我们可以使用以下语法定义一个具有动态属性的接口:interface## 如何在 TypeScript 中为对象动态添加属性在 TypeScript 中,我们经常需要在运行时动态添加属性到对象上...在本文中,我们将讨论如何在 TypeScript 中为对象动态添加属性,以及这样做的一些注意事项。...### 为对象动态添加属性的几种方法#### 方法一:使用索引签名在 TypeScript 中,我们可以使用索引签名来动态添加属性到对象上。

    11.6K20
    领券