将 typescript 错误连接到其关联的编译器选项 (tsconfig.json)
Posted
技术标签:
【中文标题】将 typescript 错误连接到其关联的编译器选项 (tsconfig.json)【英文标题】:Connecting typescript errors to their associated compiler options (tsconfig.json) 【发布时间】:2020-05-07 22:54:19 【问题描述】:如何找出与给定 Typescript 错误相关的编译器选项?
我在VSCode中使用Typescript,Typescript经常指出问题,比如initializer provides no value for this binding element
(请注意这是由 Typescript 生成的警告,而不是 TSLint)。
在tsconfig.json
,我可以关闭特定的警告,比如
"compilerOptions":
"noImplicitAny": false,
"strictPropertyInitialization": false
但据我所知,没有办法找出哪个编译器选项与哪个错误相关联。
目前有线索,但没有解决方案:
此 SO 帖子 Complete list of Typescript error codes and their fixes 提供了消息列表,但未提供使用哪个编译器选项启用/禁用消息。
不幸的是,编译器选项的名称并不模仿错误的措辞,因此您无法通过tsconfig.json
中的简单智能感知找到错误。
此外,官方文档似乎也没有提供这样的错误到选项映射:https://www.typescriptlang.org/docs/handbook/tsconfig-json.html,https://www.typescriptlang.org/docs/handbook/compiler-options.html。
所以,只是重申一下这个问题:我怎样才能找出关闭哪个编译器选项来消除给定错误?
【问题讨论】:
【参考方案1】:错误消息和编译器设置之间没有 1:1(或 1:n 或 n:1)的对应关系,并且绝大多数错误无法使用任何编译器选项关闭。许多编译器选项会以某种方式改变行为,这意味着您无法可靠地说出与其他一些选项相反的情况会发生什么。
对于确实有相应标志的错误消息,错误文本通常会提示它
"x" implicitly has type 'any'
▶ noImplicitAny
Unreachable code detected
▶ allowUnreachableCode
Unused label detected
▶ allowUnusedLabels
"x" is possibly "null"
▶ strictNullChecks
Local "x" is unused
▶ noUnusedLocals
等
【讨论】:
以上是关于将 typescript 错误连接到其关联的编译器选项 (tsconfig.json)的主要内容,如果未能解决你的问题,请参考以下文章
如何在运行时手动创建服务并将其连接到 typescript Angular 2 中的组件
将 React Redux 连接到 Typescript 中的组件
目前是不是有将两个或多个字符串文字类型连接到 TypeScript 中的单个字符串文字类型?