typescript - typescript 中联合类型的解构

标签 typescript

有没有一种方法(类似于功能语言的模式匹配)来解构 TypeScript 中的联合类型,即一些构造,如:

var a: Foo | Bar = ...;

a match {
   case f: Foo => //it's a Foo!
   case b: Bar => //it's a Bar!
}

如果没有这样的构造 - 创建这样的构造是否有任何技术困难?

最佳答案

TypeScript 理解 Type Guards作为分解联合类型的一种方式。您可以通过多种方式使用它。

如果FooBar是一个类,你可以使用instanceof:

if (a instanceof Foo) { a.doFooThing(); }

如果它们是接口(interface),你可以编写一个用户定义的类型保护:

function isFoo(f: any): f is Foo {
    // return true or false, depending....
}
if (isFoo(a)) {
   a.doFooThing();
} else {
   a.doBarThing();
}

您还可以使用 typeof a === 'string' 来测试联合中的基本类型(stringnumber bool 值)

关于typescript - typescript 中联合类型的解构,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33832475/

相关文章:

javascript - 在 typescript 类型定义中表示内部类

javascript - 测试 'isChecked' 属性是否已更改

javascript - TypeScript 错误对象原型(prototype)只能是对象或 null : undefined

typescript - 为什么 Typescript 类型检查器对这种未指定的类型感到不安?

reactjs - 使用 Typescript 在 React 项目中存储/检索配置设置

javascript - 解决在chrome中运行的tensorflow js的 "Uncaught (in promise) TypeError: fs.writeFile is not a function"的替代方法

typescript - 如何从对象数组中提取值

typescript - 在 TypeScript 编译器 API 中插入任意文本并修改 NodeArrays

javascript - 将所有图标向下旋转更改为一个

带有模板字符串的 Javascript URL