- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我有以下接口(interface)和类型(所有这些都可以更改)
interface Base {
type: string;
}
interface A extends Base {
type: "A";
field: string;
}
interface B extends Base {
type: "B";
query: string;
}
interface C extends Base {
type: "C";
equal: number;
}
type BaseExtensions = A | B | C;
interface BaseWrapper<R extends BaseExtensions> {
idType: string;
base: R;
}
interface And {
type: "AND";
rules: Array<BaseWrapper<any>>;
}
interface Or {
type: "OR";
rules: Array<BaseWrapper<any>>;
}
type Rule<R extends BaseExtensions> = BaseWrapper<R> | And | Or
我想做的是编写以下函数:
function doAThingBasedOnTheRuleType(rule: Rule<any>): Thing {
if (isAnd(rule)) {
return DoAndThing(rule);
}
if (isOr(rule)) {
return DoOrThing(rule);
}
if (isA(rule.base)) {
return DoAThing(rule);
}
if (isB(rule.base)) {
return DoBThing(rule);
}
if (isC(rule.Base)) {
return DoCThing(rule);
}
// error, [ts] Function lacks ending return statement and return type does not include 'undefined'.
}
我希望规则以 And | Or | BaseWrapper<A> | BaseWrapper<B> | BaseWrapper<C>
开头应该一一缩小范围。但是,我收到错误 // error, [ts] Function lacks ending return statement and return type does not include 'undefined'.
1- 为什么 TS 无法推断类型?2- 我该如何解决?
我在 TS 2.5.2
最佳答案
TypeScript 关于隐式返回的规则在语法上 被强制执行——在不知道涉及的类型的情况下,需要在函数的所有可到达导出点都有一个 return 语句。
要确定使用类型系统无法访问给定函数的隐式返回,将需要多次“通过”,而类型系统目前不这样做(出于性能/复杂性原因)。
例如,考虑这段代码:
function fn1() {
const f = fn2();
if (f === "alpha") {
return "A";
} else if (f === "beta") {
return "B";
}
}
function fn2() {
const f = fn1();
if (f === "A") {
return "alpha";
} else if (f === "B") {
return "beta";
}
return "gamma";
}
fn1()
的类型是什么?它可以是 "A"| “乙” | undefined
如果 fn2()
返回的值不是 "alpha"
或 "beta"
,或者它可能是 “一个” | "B"
如果这些是唯一的返回值。好吧,让我们检查一下 fn2()
—— 它的返回类型是什么? 那 取决于fn1()
的类型——fn2
返回“alpha” | "beta"
如果 fn1
只返回 "A"| "B"
,或返回 "alpha"| “测试版” | "gamma"
如果 undefined
是可能的返回值。
因此,要弄清楚 fn1
的隐式返回的可达性,您必须进行多“轮”推理,根据另一个函数的类型改进一个函数的类型,然后重复,希望您到达一个固定点并且不要无限递归。这比使用隐式返回的句法强制执行单次传递要很多昂贵。
最简单的解决方法是简单地添加一个throw
:
} else if (...) {
return ...;
}
throw new Error("Shouldn't be reachable");
}
或者,如果您真的很喜欢代码覆盖率,请将 if
条件重写为最后一个 block 中的断言:
} else {
Debug.assert(x.kind === "B");
return "C";
}
关于typescript - 函数 "lacks return statement"但所有路径都有类型保护,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46433840/
在 go lang 中使用“If with a short statement”有什么好处。引用:go tour if v := math.Pow(x, n); v < lim { retur
完全错误: Warning: Unsafe statement written to the binary log using statement format since BINLOG_FORMAT
完全错误: Warning: Unsafe statement written to the binary log using statement format since BINLOG_FORMAT
我有三个存储过程 Sp1、Sp2 和 Sp3。 第一个 (Sp1) 将执行第二个 (Sp2) 并将返回的数据保存到 @tempTB1 中,第二个将执行第三个 (Sp3) 并将数据保存到 @tempTB
我已将 FLAG 设置为 1,并且正在执行 ARG 值应该仅为 DEV。但是我得到的是 ARG= DEV + CLIENTID 000023 // FLAG=1 000026 // I
我已将 FLAG 设置为 1,并且正在执行 ARG 值应该仅为 DEV。但是我得到的是 ARG= DEV + CLIENTID 000023 // FLAG=1 000026 // I
已关闭。这个问题是 not reproducible or was caused by typos 。目前不接受答案。 这个问题是由拼写错误或无法再重现的问题引起的。虽然类似的问题可能是 on-top
PMD告诉我 A switch with less than 3 branches is inefficient, use a if statement instead. 这是为什么呢?为什么是3?他
我刚开始学习 Racket,所以我仍在努力弄清楚这门语言的复杂性。我正在尝试在列表中实现我自己的搜索功能。如果函数找到它,则返回索引,否则返回 -1。 (define (find-index list
在 Kotlin 中,您可以使用类似于三元运算符的 if 语句。 我们可以选择做这样的事情: val x = if (isOdd) 1 else 2 但是如果我们有多个变量需要根据某些条件进行设置,那
在我的 Android 应用程序中,我尝试使用 XMLPullParser 使用以下代码读取 xml 文件: while (eventType != XmlPullParser.END_DOCUMEN
这个问题已经有答案了: Boolean expressions in Java (8 个回答) 已关闭 7 年前。 我遇到过一些情况,其中第一个似乎改变了 boolean 值,而第二个却没有!两者之间
我基本上想做的是: select * from request where id = 1 and created_at like (today's date); 但使用 Eloquent 。 我试过:
我不确定为什么会收到此代码。基本上我希望能够动态定位我的发射器,但是当我添加一个选项来检查位置并根据需要进行纠正时,我不断收到此错误。 添加的代码是 if (
何时使用语句而不是准备语句。我想语句用于没有参数的查询,但为什么不使用准备好的语句呢?对于没有参数的查询,哪个更快。 最佳答案 I suppose statement is used in queri
我必须创建一个表,如下所示 借款人(客户编号,贷款编号) 如果客户没有超过 3 笔贷款,则可以贷款。 我创建的表如下 create table borrower( customerno int(5),
这个问题在这里已经有了答案: 关闭 12 年前。 Possible Duplicates: Is "else if" faster than "switch() case"? What is the
typescript 版本 2.2.2 我在我的 UserRoutzr.ts 中写了这个要求 const users = require(path.join(process.cwd() + "/da
我有一个用 JPQL 编写的应用程序,它可以命中非常不同的查询(在不同的资源上)。 对于很多此类查询,我需要知道结果总数(计数),因为我没有应用任何 LIMIT/OFFSET 由于此查询的性质非常不同
我对以下 Java 语句感到困惑: ArtClass artClass0 = new ArtClass(); int int3 = 73; boolean boolean0 = artClass0.f
我是一名优秀的程序员,十分优秀!