使用
"@angular/cli": "^1.0.0"
@angular/cli
忽略tsconfig.json
项目编辑/删除tsconfig.json
为什么?
答案 0 :(得分: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.json
中所述,app
支持“此项目中不同应用程序的属性。”
"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 build
,ng e2e
,ng eject
,ng test
和ng xi18n
。要将新应用添加到现有$ROOT
目录,请使用ng new
。
根tsconfig
不仅适用于代码编辑器和tslint
。它适用于项目中的所有应用程序。它的工作原理相当复杂,从the source code可以清楚地看出,其中有许多json文件都有"extends": "../../../tsconfig.json"
这样的行。
答案 1 :(得分:5)
看似愚蠢,angular-cli的tsconfig.json
文件位于src/tsconfig.app.json
编辑器将使用根tsconfig.json
(例如vscode)。