tsconfig.json配置詳解
概述
如果一個(gè)目錄下存在一個(gè)tsconfig.json文件,那么它意味著這個(gè)目錄是TypeScript項(xiàng)目的根目錄。 tsconfig.json文件中指定了用來(lái)編譯這個(gè)項(xiàng)目的根文件和編譯選項(xiàng)。 一個(gè)項(xiàng)目可以通過(guò)以下方式之一來(lái)編譯:
使用tsconfig.json
- 不帶任何輸入文件的情況下調(diào)用tsc,編譯器會(huì)從當(dāng)前目錄開(kāi)始去查找tsconfig.json文件,逐級(jí)向上搜索父目錄。
- 不帶任何輸入文件的情況下調(diào)用tsc,且使用命令行參數(shù)--project(或-p)指定一個(gè)包含tsconfig.json文件的目錄。
當(dāng)命令行上指定了輸入文件時(shí),tsconfig.json文件會(huì)被忽略。
示例
tsconfig.json示例文件:
使用"files"屬性
{
"compilerOptions": {
"module": "commonjs",
"noImplicitAny": true,
"removeComments": true,
"preserveConstEnums": true,
"sourceMap": true
},
"files": [
"core.ts",
"sys.ts",
"types.ts",
"scanner.ts",
"parser.ts",
"utilities.ts",
"binder.ts",
"checker.ts",
"emitter.ts",
"program.ts",
"commandLineParser.ts",
"tsc.ts",
"diagnosticInformationMap.generated.ts"
]
}
使用"include"和"exclude"屬性
{
"compilerOptions": {
"module": "system",
"noImplicitAny": true,
"removeComments": true,
"preserveConstEnums": true,
"outFile": "../../built/local/tsc.js",
"sourceMap": true
},
"include": [
"src/**/*"
],
"exclude": [
"node_modules",
"**/*.spec.ts"
]
}
細(xì)節(jié)
"compilerOptions"可以被忽略,這時(shí)編譯器會(huì)使用默認(rèn)值。在這里查看完整的編譯器選項(xiàng)列表。
"files"指定一個(gè)包含相對(duì)或絕對(duì)文件路徑的列表。 "include"和"exclude"屬性指定一個(gè)文件glob匹配模式列表。 支持的glob通配符有:
- * 匹配0或多個(gè)字符(不包括目錄分隔符)
- ? 匹配一個(gè)任意字符(不包括目錄分隔符)
- **/ 遞歸匹配任意子目錄
如果一個(gè)glob模式里的某部分只包含*或.*,那么僅有支持的文件擴(kuò)展名類型被包含在內(nèi)(比如默認(rèn).ts,.tsx,和.d.ts, 如果allowJs設(shè)置能true還包含.js和.jsx)。
如果"files"和"include"都沒(méi)有被指定,編譯器默認(rèn)包含當(dāng)前目錄和子目錄下所有的TypeScript文件(.ts, .d.ts 和 .tsx),排除在"exclude"里指定的文件。JS文件(.js和.jsx)也被包含進(jìn)來(lái)如果allowJs被設(shè)置成true。 如果指定了 "files"或"include",編譯器會(huì)將它們結(jié)合一并包含進(jìn)來(lái)。 使用 "outDir"指定的目錄下的文件永遠(yuǎn)會(huì)被編譯器排除,除非你明確地使用"files"將其包含進(jìn)來(lái)(這時(shí)就算用exclude指定也沒(méi)用)。
使用"include"引入的文件可以使用"exclude"屬性過(guò)濾。 然而,通過(guò) "files"屬性明確指定的文件卻總是會(huì)被包含在內(nèi),不管"exclude"如何設(shè)置。 如果沒(méi)有特殊指定, "exclude"默認(rèn)情況下會(huì)排除node_modules,bower_components,jspm_packages和<outDir>目錄。
任何被"files"或"include"指定的文件所引用的文件也會(huì)被包含進(jìn)來(lái)。A.ts引用了B.ts,因此B.ts不能被排除,除非引用它的A.ts在"exclude"`列表中。
需要注意編譯器不會(huì)去引入那些可能做為輸出的文件;比如,假設(shè)我們包含了index.ts,那么index.d.ts和index.js會(huì)被排除在外。 通常來(lái)講,不推薦只有擴(kuò)展名的不同來(lái)區(qū)分同目錄下的文件。
tsconfig.json文件可以是個(gè)空文件,那么所有默認(rèn)的文件(如上面所述)都會(huì)以默認(rèn)配置選項(xiàng)編譯。
在命令行上指定的編譯選項(xiàng)會(huì)覆蓋在tsconfig.json文件里的相應(yīng)選項(xiàng)。
@types,typeRoots和types
默認(rèn)所有可見(jiàn)的"@types"包會(huì)在編譯過(guò)程中被包含進(jìn)來(lái)。 node_modules/@types文件夾下以及它們子文件夾下的所有包都是可見(jiàn)的; 也就是說(shuō), ./node_modules/@types/,../node_modules/@types/和../../node_modules/@types/等等。
如果指定了typeRoots,只有typeRoots下面的包才會(huì)被包含進(jìn)來(lái)。 比如:
{
"compilerOptions": {
"typeRoots" : ["./typings"]
}
}
這個(gè)配置文件會(huì)包含所有./typings下面的包,而不包含./node_modules/@types里面的包。
如果指定了types,只有被列出來(lái)的包才會(huì)被包含進(jìn)來(lái)。 比如:
{
"compilerOptions": {
"types" : ["node", "lodash", "express"]
}
}
這個(gè)tsconfig.json文件將僅會(huì)包含 ./node_modules/@types/node,./node_modules/@types/lodash和./node_modules/@types/express。/@types/。 node_modules/@types/*里面的其它包不會(huì)被引入進(jìn)來(lái)。
指定"types": []來(lái)禁用自動(dòng)引入@types包。
注意,自動(dòng)引入只在你使用了全局的聲明(相反于模塊)時(shí)是重要的。 如果你使用 import "foo"語(yǔ)句,TypeScript仍然會(huì)查找node_modules和node_modules/@types文件夾來(lái)獲取foo包。
使用extends繼承配置
tsconfig.json文件可以利用extends屬性從另一個(gè)配置文件里繼承配置。
extends是tsconfig.json文件里的頂級(jí)屬性(與compilerOptions,files,include,和exclude一樣)。 extends的值是一個(gè)字符串,包含指向另一個(gè)要繼承文件的路徑。
在原文件里的配置先被加載,然后被來(lái)至繼承文件里的配置重寫。 如果發(fā)現(xiàn)循環(huán)引用,則會(huì)報(bào)錯(cuò)。
來(lái)至所繼承配置文件的files,include和exclude覆蓋源配置文件的屬性。
配置文件里的相對(duì)路徑在解析時(shí)相對(duì)于它所在的文件。
比如:
configs/base.json:
{
"compilerOptions": {
"noImplicitAny": true,
"strictNullChecks": true
}
}
tsconfig.json:
{
"extends": "./configs/base",
"files": [
"main.ts",
"supplemental.ts"
]
}
tsconfig.nostrictnull.json:
{
"extends": "./tsconfig",
"compilerOptions": {
"strictNullChecks": false
}
}
compileOnSave
在最頂層設(shè)置compileOnSave標(biāo)記,可以讓IDE在保存文件的時(shí)候根據(jù)tsconfig.json重新生成文件。
{
"compileOnSave": true,
"compilerOptions": {
"noImplicitAny" : true
}
}
要想支持這個(gè)特性需要Visual Studio 2015, TypeScript1.8.4以上并且安裝atom-typescript插件
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
基于JS開(kāi)發(fā)微信網(wǎng)頁(yè)錄音功能的實(shí)例代碼
這篇文章主要介紹了基于JS開(kāi)發(fā)微信網(wǎng)頁(yè)錄音功能的實(shí)例代碼,代碼簡(jiǎn)單易懂,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-04-04
TypeScript之調(diào)用棧的實(shí)現(xiàn)
這篇文章主要介紹了TypeScript之調(diào)用棧的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-12-12
跟我學(xué)習(xí)javascript的var預(yù)解析與函數(shù)聲明提升
跟我學(xué)習(xí)javascript的var預(yù)解析與函數(shù)聲明提升,小編對(duì)var預(yù)解析與函數(shù)聲明提升知識(shí)點(diǎn)也不甚了解,和大家一起學(xué)習(xí)本篇文章。2015-11-11
JavaScript中this的全面解析及常見(jiàn)實(shí)例
這篇文章主要給大家介紹了關(guān)于JavaScript中this的全面解析及常見(jiàn)實(shí)例的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用JavaScript具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-05-05
javascript編程異常處理實(shí)例小結(jié)
這篇文章主要介紹了javascript編程異常處理的方法,結(jié)合實(shí)例形式分析總結(jié)了JavaScript編程中異常處理的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-11-11

