這篇文章主要為大家展示了“tsconfig.json配置的示例分析”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“tsconfig.json配置的示例分析”這篇文章吧。
創(chuàng)新互聯(lián)專注為客戶提供全方位的互聯(lián)網(wǎng)綜合服務(wù),包含不限于成都網(wǎng)站設(shè)計、網(wǎng)站建設(shè)、外貿(mào)網(wǎng)站建設(shè)、峨山縣網(wǎng)絡(luò)推廣、小程序制作、峨山縣網(wǎng)絡(luò)營銷、峨山縣企業(yè)策劃、峨山縣品牌公關(guān)、搜索引擎seo、人物專訪、企業(yè)宣傳片、企業(yè)代運營等,從售前售中售后,我們都將竭誠為您服務(wù),您的肯定,是我們最大的嘉獎;創(chuàng)新互聯(lián)為所有大學(xué)生創(chuàng)業(yè)者提供峨山縣建站搭建服務(wù),24小時服務(wù)熱線:18982081108,官方網(wǎng)址:aaarwkj.com
概述
如果一個目錄下存在一個tsconfig.json文件,那么它意味著這個目錄是TypeScript項目的根目錄。 tsconfig.json文件中指定了用來編譯這個項目的根文件和編譯選項。 一個項目可以通過以下方式之一來編譯:
使用tsconfig.json
不帶任何輸入文件的情況下調(diào)用tsc,編譯器會從當(dāng)前目錄開始去查找tsconfig.json文件,逐級向上搜索父目錄。
不帶任何輸入文件的情況下調(diào)用tsc,且使用命令行參數(shù)--project(或-p)指定一個包含tsconfig.json文件的目錄。
當(dāng)命令行上指定了輸入文件時,tsconfig.json文件會被忽略。
示例
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" ] }
細節(jié)
"compilerOptions"可以被忽略,這時編譯器會使用默認值。在這里查看完整的編譯器選項列表。
"files"指定一個包含相對或絕對文件路徑的列表。 "include"和"exclude"屬性指定一個文件glob匹配模式列表。 支持的glob通配符有:
* 匹配0或多個字符(不包括目錄分隔符)
? 匹配一個任意字符(不包括目錄分隔符)
**/ 遞歸匹配任意子目錄
如果一個glob模式里的某部分只包含*或.*,那么僅有支持的文件擴展名類型被包含在內(nèi)(比如默認.ts,.tsx,和.d.ts, 如果allowJs設(shè)置能true還包含.js和.jsx)。
如果"files"和"include"都沒有被指定,編譯器默認包含當(dāng)前目錄和子目錄下所有的TypeScript文件(.ts, .d.ts 和 .tsx),排除在"exclude"里指定的文件。JS文件(.js和.jsx)也被包含進來如果allowJs被設(shè)置成true。 如果指定了 "files"或"include",編譯器會將它們結(jié)合一并包含進來。 使用 "outDir"指定的目錄下的文件永遠會被編譯器排除,除非你明確地使用"files"將其包含進來(這時就算用exclude指定也沒用)。
使用"include"引入的文件可以使用"exclude"屬性過濾。 然而,通過 "files"屬性明確指定的文件卻總是會被包含在內(nèi),不管"exclude"如何設(shè)置。 如果沒有特殊指定, "exclude"默認情況下會排除node_modules,bower_components,jspm_packages和<outDir>目錄。
任何被"files"或"include"指定的文件所引用的文件也會被包含進來。A.ts引用了B.ts,因此B.ts不能被排除,除非引用它的A.ts在"exclude"`列表中。
需要注意編譯器不會去引入那些可能做為輸出的文件;比如,假設(shè)我們包含了index.ts,那么index.d.ts和index.js會被排除在外。 通常來講,不推薦只有擴展名的不同來區(qū)分同目錄下的文件。
tsconfig.json文件可以是個空文件,那么所有默認的文件(如上面所述)都會以默認配置選項編譯。
在命令行上指定的編譯選項會覆蓋在tsconfig.json文件里的相應(yīng)選項。
@types,typeRoots和types
默認所有可見的"@types"包會在編譯過程中被包含進來。 node_modules/@types文件夾下以及它們子文件夾下的所有包都是可見的; 也就是說, ./node_modules/@types/,../node_modules/@types/和../../node_modules/@types/等等。
如果指定了typeRoots,只有typeRoots下面的包才會被包含進來。 比如:
{ "compilerOptions": { "typeRoots" : ["./typings"] } }
這個配置文件會包含所有./typings下面的包,而不包含./node_modules/@types里面的包。
如果指定了types,只有被列出來的包才會被包含進來。 比如:
{ "compilerOptions": { "types" : ["node", "lodash", "express"] } }
這個tsconfig.json文件將僅會包含 ./node_modules/@types/node,./node_modules/@types/lodash和./node_modules/@types/express。/@types/。 node_modules/@types/*里面的其它包不會被引入進來。
指定"types": []來禁用自動引入@types包。
注意,自動引入只在你使用了全局的聲明(相反于模塊)時是重要的。 如果你使用 import "foo"語句,TypeScript仍然會查找node_modules和node_modules/@types文件夾來獲取foo包。
使用extends繼承配置
tsconfig.json文件可以利用extends屬性從另一個配置文件里繼承配置。
extends是tsconfig.json文件里的頂級屬性(與compilerOptions,files,include,和exclude一樣)。 extends的值是一個字符串,包含指向另一個要繼承文件的路徑。
在原文件里的配置先被加載,然后被來至繼承文件里的配置重寫。 如果發(fā)現(xiàn)循環(huán)引用,則會報錯。
來至所繼承配置文件的files,include和exclude覆蓋源配置文件的屬性。
配置文件里的相對路徑在解析時相對于它所在的文件。
比如:
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在保存文件的時候根據(jù)tsconfig.json重新生成文件。
{ "compileOnSave": true, "compilerOptions": { "noImplicitAny" : true } }
要想支持這個特性需要Visual Studio 2015, TypeScript1.8.4以上并且安裝atom-typescript插件
以上是“tsconfig.json配置的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!
文章名稱:tsconfig.json配置的示例分析
網(wǎng)站路徑:http://aaarwkj.com/article34/godcse.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站制作、虛擬主機、ChatGPT、關(guān)鍵詞優(yōu)化、微信小程序、外貿(mào)網(wǎng)站建設(shè)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)