9

使用

"@angular/cli": "^1.0.0"

@angular/cli忽略tsconfig.json

该项目编译得很好编辑/删除tsconfig.json

这是为什么?

4

2 回答 2

8

您的项目编译没有 $ROOT/tsconfig.json的原因是@angular/cli支持根目录中的多个应用程序;您的(单个)应用程序正在编译,$ROOT/src/tsconfig.app.json您的测试套件使用$ROOT/src/tsconfig.spec.json. 根tsconfig.json适用于目录中的所有应用程序。删除它只是删除了可能与许多应用程序一起使用的全局。 tsconfig

为了更清楚地理解这一点,请查看.angular-cli.json. 一个属性app支持多个应用程序的数组,但默认配置仅针对一个应用程序。如 中所述@angular/cli/lib/config/schema.jsonapp支持“此项目中不同应用程序的属性”。

"app": [{
  "root": "src"
  ...
  "tsconfig": "tsconfig.app.json",
  "testTsconfig": "tsconfig.spec.json"
}]

使用这个数组,您可以拥有任意数量的 Angular 应用程序,每个应用程序都有自己特定的 TypeScript 设置。

此外,@angular/cli的命令支持带有--app标志的多个应用程序。ng serve --app foo将为foo应用程序提供服务,而ng serve --app bar将为bar应用程序提供服务。此标志也适用于ng buildng e2eng ejectng testng xi18n。要将新应用添加到现有$ROOT目录,请使用ng new.

tsconfig不仅适用于代码编辑器和tslint. 它适用于您项目中的所有应用程序。从源代码中可以清楚地看出,这在幕后是如何工作的相当复杂,其中有许多 json 文件,其中包含"extends": "../../../tsconfig.json".

于 2017-06-21T17:14:59.543 回答
6

尽管看起来很愚蠢,但 angular-cli 的tsconfig.json文件位于内部src/tsconfig.app.json

tsconfig.json编辑器(例如 vscode)将使用根目录。

于 2017-03-31T09:13:34.083 回答