No more than code.
Typescript 项目配置
项目配置参考:https://www.tslang.cn/docs/handbook/tsconfig-json.html
tsconfig.json
tsconfig.json 文件中指定了用来编译这个项目的根文件和编译选项。tsconfig.json 文件可以是个空文件,那么所有默认的文件都会以默认配置选项编译。
{
"compilerOptions": {
"module": "commonjs",
"noImplicitAny": true,
"removeComments": true,
"preserveConstEnums": true,
"sourceMap": true,
"outFile": "../../built/local/tsc.js",
},
// "files" 指定一个包含相对或绝对文件路径的列表。
"files": [
"core.ts",
],
"include": [
"src/**/*"
],
"exclude": [
"node_modules",
"**/*.spec.ts"
]
}
include & exclude & files & outDir
“include” 和 “exclude” 属性指定一个文件 glob 匹配模式列表。 支持的 glob 通配符有:
-
- 匹配0或多个字符(不包括目录分隔符)
- ? 匹配一个任意字符(不包括目录分隔符)
- **/ 递归匹配任意子目录
解释说明:
-
指定了 “files” 或 “include”,编译器会将它们结合一并包含进来。任何被 “files” 或 “include” 指定的文件所引用的文件也会被包含进来。
-
如果 “files” 和 “include” 都没有被指定,编译器默认包含当前目录和子目录下所有的TypeScript文件(.ts, .d.ts 和 .tsx),排除在 “exclude” 里指定的文件。
-
如果 allowJs 被设置成 true,JS文件(.js和.jsx)也被包含进来。
-
使用 “outDir” 指定的目录下的文件永远会被编译器排除,除非你明确地使用 “files” 将其包含进来。
-
使用 “include” 引入的文件可以使用 “exclude” 属性过滤。 然而,通过 “files”属性明确指定的文件却总是会被包含在内,不管 “exclude” 如何设置。 如果没有特殊指定, “exclude”默认情况下会排除 node_modules,bower_components,jspm_packages和
目录
@types,typeRoots和types
默认所有可见的 “@types” 包会在编译过程中被包含进来。 node_modules/@types 文件夹下以及它们子文件夹下的所有包都是可见的;
{
"compilerOptions": {
"typeRoots" : ["./typings"],
"types" : ["node", "lodash", "express"]
}
}
如果指定了 typeRoots,只有 typeRoots 下面的包才会被包含进来。 如果指定了 types,只有被列出来的包才会被包含进来。
extends
tsconfig.json 文件可以利用 extends 属性从另一个配置文件里继承配置。 extends 是 tsconfig.json 文件里的顶级属性(与compilerOptions,files,include,和exclude一样)。 extends 的值是一个字符串,包含指向另一个要继承文件的路径。
// configs/base.json
{
"compilerOptions": {
"noImplicitAny": true,
"strictNullChecks": true
}
}
// tsconfig.json
{
"extends": "./configs/base",
"files": [
"main.ts",
"supplemental.ts"
]
}
compileOnSave
在最顶层设置 compileOnSave 标记,可以让IDE在保存文件的时候根据 tsconfig.json 重新生成文件
{
"compileOnSave": true,
"compilerOptions": {
"noImplicitAny" : true
}
}
path
解决报错:
Cannot find module '@/utils/http/index' or its corresponding type declarations
"baseUrl": ".",
"paths": {
"@/*": ["src/*"]
}