- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
使用 Typescript 3.7 nullish coalescing operator被介绍了。对于像这样的情况,它似乎是完美的类型保护
const fs = (s: string) => s
const fn = (n: number) => n
let a: string | null | undefined
let b: number | null | undefined
const x = (a ?? null) && fs(a)
const y = (b ?? null) && fn(b)
const fs = (str: string) => str
const create = (s: string) => s === 's' ? 'string' : s === 'n' ? null : undefined
const a: string | null | undefined = create('s')
const b: string | null | undefined = 's'
let x
if (a !== null && a !== undefined) {
x = a
} else {
x = fs(a)
}
const x1 = a !== null && a !== undefined && fs(a)
const x2 = a !== null && a !== void 0 && fs(a)
const x3 = (a ?? null) && fs(a)
const x4 = (b ?? null) && fs(b)
const x5 = a !== null && a !== undefined ? a : fs(a)
const something = a !== null && a !== undefined
const x6 = something ? a : fs(a)
const x7 = something && fs(a)
const x8 = (a !== null && a !== undefined) && fs(a)
最佳答案
我花了很长时间试图写出为什么像 expr1 || expr2 && expr3
这样的特定表达式的机械解释。在某些情况下而不是在其他情况下充当类型守卫。它最终变成了几页,但仍然没有考虑到您示例中的所有情况。如果你关心你可以查看为 expression operators 实现的代码在 microsoft/TypeScript#7140 .
一个更高级的解释为什么这个限制和类似的限制存在:当你,一个人,看到一个联合类型的值时,你可以决定通过想象如果将值缩小到每个成员会发生什么来分析它对于该值存在的整个范围,属于该类型。如果您的代码在每个这样的案例分析中表现良好,那么它在完整联合中表现良好。这个决定大概是基于您对所讨论代码的行为的关心程度,或者我们无法希望由编译器重现的其他一些认知过程做出的。
编译器可能一直对它遇到的每个可能的联合类型表达式进行这种分析。我们可以称之为“自动分布式控制流分析”,它的好处是几乎总是能产生你想要的类型保护行为。缺点是编译器需要的内存和时间比您愿意花费的要多,并且可能比人类能够花费的更多,因为每个额外的联合类型表达式都会对所需资源。指数时间算法不适合优秀的编译器。
有时,我希望能够向编译器暗示应该以这种方式分析特定范围内的特定联合类型值,我什至提交了此类“选择加入分布式控制流分析”的请求,(参见 microsoft/TypeScript#25051 ),但即使这样也需要大量的开发工作来实现,并且会偏离启用 JS 设计模式的 TS 设计目标,而无需开发人员对控制流分析考虑太多。
因此,最终,TypeScript 语言设计人员所做的是实现启发式方法,在有限的范围内执行此类分析,从而支持传统和惯用的 JavaScript 编码模式。如果代码如 (a ?? null) && fs(a)
对于语言设计者来说,它被认为不够惯用和传统(这部分是主观的,部分取决于检查真实世界代码的语料库),如果实现它会导致编译器性能下降,那么我不会期望语言来支持它。
一些例子:
something
示例)以供以后使用。这是一个标记为“重新访问”的公开建议,语言架构师宣布很难以高性能的方式实现它。这可能是惯用的,但可能很难有效实现。关于typescript - 为什么无效合并运算符不能作为 typescript 中的打字员工作?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61218232/
我已经写了并且 npm 发布了这个:https://github.com/justin-calleja/pkg-dependents 现在我正在用 Typescript 编写这个包:https://g
我有一个函数,我想在 TypeScript 中模拟它以进行测试。在我的测试中,我只关心 json和 status .但是,当使用 Jest 的 jest.spyOn 时我的模拟函数的类型设置为返回 h
我正在使用一个库 (Axios),它的包中包含 Typescript 声明。 我想声明一个将 AxiosResponse(在库的 .d.ts 文件中声明)作为参数的函数。我有以下内容: functio
我是 Typescript 的新手。我想使用 将一个 Typescript 文件加载到另一个 Typescript 文件中标签。 我做了一些事情,但它不起作用!请帮助我。 first.ts: imp
为什么我会收到下面屏幕截图中显示的错误? Atom 说我的 tsconfig.json“项目文件包含无效选项”用于 allowJs、buildOnSave 和 compileOnSave。 但是应该允
所以我正在创建一个 TypeScript 库,我可以轻松地将所有生成的 JS 文件编译成一个文件。有没有办法将所有 .ts 和 .d.ts 编译成一个 .ts 文件? 除了支持 JS 的版本(较少的智
Microsoft Research 提供了一种名为Safer TypeScript 的新 TypeScript 编译器变体: http://research.microsoft.com/en-us/
我需要这个来在单个文件中分发 TypeScript 中的库。有没有办法将多个 typescript 文件合并到(一个js文件+一个 typescript 定义)文件中? 最佳答案 要创建一个库,您可以
用例:我想知道一个函数在 typescript 中执行需要多少时间。我想为此目的使用装饰器。我希望装饰器应该返回时间以便(我可以进一步使用它),而不仅仅是打印它。 例如: export functio
我想检查一个类型是否可以为 null,以及它是否具有值的条件类型。 我尝试实现 type IsNullable = T extends null ? true : false; 但是好像不行 type
我的问题是基于这个 question and answer 假设我们有下一个代码: const myFn = (p: { a: (n: number) => T, b: (o: T) => v
我知道双重否定前缀,我知道 TypeScript 的单后缀(非空断言)。 但是这个双后缀感叹号是什么? /.*验证码为(\d{6}).*/.exec(email.body!!)!![1] 取自here
我正在使用以下文件结构在 Webstorm 中开发一个项目 | src | ... | many files | types | SomeInterface |
在 TypeScript 类中,可以为属性声明类型,例如: class className { property: string; }; 如何在对象字面量中声明属性的类型? 我试过下面的代码,但它
我正在寻找一种在不丢失推断类型信息的情况下将 TypeScript 中的文字值限制为特定类型的好方法。 让我们考虑一个类型Named,它保证有一个名字。 type Named = { name:
在 TypeScript 中,我想创建一个联合类型来表示属于一个或多个不同类型的值,类似于 oneOf在 OpenAPI或 JSON Schema .根据a previous answer on a
type Func = (foo:string) => void // function expression const myFunctionExpression:Func = function(f
假设我有一个联合类型,我正在使用类似 reducer 的 API 调用模式,看起来像这样: type Action = { request: { action: "create
我在 typescript 中有以下去抖功能: export function debounce( callback: (...args: any[]) => void, wait: numb
在 Vue3 的 defineComponent 函数中,第一个泛型参数是 Props,所以我在这里使用 Typescript 接口(interface)提供我的 props 类型。喜欢: expor
我是一名优秀的程序员,十分优秀!