TypeScript - Как сохранить скомпилированные файлы в отдельном каталоге?
Я новичок в TypeScript, и прямо сейчас у меня есть файлы .ts в нескольких местах, пронизывая мою структуру проекта:
app/
|-scripts/
|-app.ts
|
|-classes/
| |-classA.ts
| |-classB.ts
|
|-controllers/
| |-controllerA.ts
| |-controllerB.ts
|
|-otherStuff/
|-otherstuffA.ts
Прямо сейчас, когда мои файлы скомпилированы, они скомпилированы в ту же директорию, в которой находятся .ts fles:
app/
|-scripts/
|-app.ts
|-app.js
|
|-classes/
| |-classA.ts
| |-classB.ts
| |-classA.js
| |-classB.js
|
|-controllers/
| |-controllerA.ts
| |-controllerB.ts
| |-controllerA.js
| |-controllerB.js
|
|-otherStuff/
|-otherstuffA.ts
|-otherStuffA.js
В то время как мне нравится, как файлы .js сохраняют ту же структуру каталогов, что и файлы .ts, я не хочу отслеживать файлы .js в своем VCS, поэтому я хотел бы сохранить весь свой JavaScript файлы в отдельном дереве каталогов (который затем я могу добавить в .gitignore), например:
app/
|-scripts/
| |-app.ts
| |
| |-classes/
| | |-classA.ts
| | |-classB.ts
| |
| |-controllers/
| | |-controllerA.ts
| | |-controllerB.ts
| |
| |-otherStuff/
| |-otherstuffA.ts
|
|-js/
|-app.js
|
|-classes/
| |-classA.js
| |-classB.js
|
|-controllers/
| |-controllerA.js
| |-controllerB.js
|
|-otherStuff/
|-otherstuffA.js
Есть ли параметр или параметр где-нибудь, что скажет компилятору TypeScript сделать это? Кроме того, я не уверен, что это актуально, но я использую WebStorm.
Ответы
Ответ 1
Используйте параметр --outDir
для tsc (настроенный в Хранителе файлов в IntelliJ)
В документации по командной строке
--outDir DIRECTORY Redirect output structure to the directory.
Edit
Так как Typescript 1.5, это также можно установить в файле tsconfig.json
:
"compilerOptions": {
"outDir": "DIRECTORY"
...
Ответ 2
Или добавьте "outDir": "build"
в файл tsconfig.json
Ответ 3
Если вам нравится сопоставлять структуру каталогов в папке app/scripts в js, я бы предложил использовать следующие параметры для наблюдателя файлов:
Arguments: --sourcemap --outDir $ProjectFileDir$/js/$FileDirPathFromParent(scripts)$ $FileName$
Working Directory: $FileDir$
Output Paths To Refresh: $ProjectFileDir$/js/$FileDirPathFromParent(scripts)$/$FileNameWithoutExtension$.js:$ProjectFileDir$/js/$FileDirPathFromParent(scripts)$/$FileNameWithoutExtension$.js.map
Ответ 4
Я устанавливаю package.json так, чтобы набрав npm run start
выводил все на build
. Исходные файлы хранятся в src
. Исходный файл указан --outDir build
.
{
"name": "myapp",
"version": "0.0.1",
"scripts": {
"tsc": "tsc",
"tsc:w": "tsc -w --outDir build",
"lite": "lite-server",
"start": "concurrent \"npm run tsc:w\" \"npm run lite\" "
},
"license": "private",
"dependencies": {
"angular2": "2.0.0-beta.0",
"systemjs": "0.19.6",
"es6-promise": "^3.0.2",
"es6-shim": "^0.33.3",
"reflect-metadata": "0.1.2",
"rxjs": "5.0.0-beta.0",
"zone.js": "0.5.10"
},
"devDependencies": {
"concurrently": "^1.0.0",
"lite-server": "^1.3.1",
"typescript": "^1.7.3"
}
}
Вы можете исключить свой каталог сборки в tsconfig.json, хотя, вероятно, это не обязательно, поскольку там есть только JS:
{
"compilerOptions": {
"target": "ES5",
"module": "system",
"moduleResolution": "node",
"sourceMap": true,
"emitDecoratorMetadata": true,
"experimentalDecorators": true,
"removeComments": false,
"noImplicitAny": false
},
"exclude": [
"node_modules",
"build"
]
}
Ответ 5
Хотя эти ответы правильные, вы должны подумать о том, хотите ли вы просто скрыть ваши .js файлы из вашей среды IDE.
В коде Visual Studio перейдите в File > Preferences > Settings
или ваш .vscode\settings.json
файл и введите:
"files.exclude": {
"**/.git": true,
"**/.DS_Store": true,
"**/*.js" : {
"when": "$(basename).ts"
},
"**/*.js.map": {
"when": "$(basename)"
}
}
Вышеупомянутый скрывает файлы .js, где существует соответствующий файл .ts.
Ответ 6
Intellij Users, скомпилируйте Typescript в несколько каталогов вывода
Для пользователей Intellij это может быть полезно. Вот как я получил эту работу, используя встроенный компилятор Typescript.
Информация о среде
Пример структуры каталогов
BEFORE COMPILE
----------------------------------------
-> JS
-> app
-> config.js //this is not generated
-> libs
-> jquery.js //this is not generated
-> plugins
-> TS
-> app
-> main.ts
-> libs
-> jquery.d.ts
-> plugins
-> somePlugin.ts
AFTER COMPILE
----------------------------------------
-> JS
-> app
-> config.js //this is not generated
-> main.js
-> libs
-> jquery.js //this is not generated
-> plugins
somePlugin.ts
-> TS
-> app
-> main.ts
-> libs
-> jquery.d.ts //this is where I kept my definition files
-> plugins
-> somePlugin.ts
Intellij Setup
- Файл → Настройки → Typescript
- Node Интерпретатор: путь установки NodeJS
- Версия компилятора: обычно находится в
C:\yourUserName\AppData\Roaming\npm\node_modules\typescript\lib
- Параметры командной строки:
-m amd -t ES6 -outDir E:\myapp\js
- Проверить только основной файл компиляции и указать его в файл ввода.
E:\myapp\ts\main.ts
Если это не проверено, все ваши файлы будут пытаться выводить на ваш путь outDir.
![введите описание изображения здесь]()
Ответ 7
Я использую Atom с расширением atom- typescript, а мой tsconfig.json выглядит так:
{
"compilerOptions": {
"outDir":"js"
}
}
Ответ 8
Что касается Grunt, в настоящее время для сохранения вашей структуры проекта папок Dev в производстве и не получить неожиданный результат после компиляции файлов, обратитесь к опции:
compilerOptions: {
rootDir: 'devFolder'
// ...
}
См. Параметр rootDir в официальных документах grunt-ts.
Я надеюсь, что это поможет кому-то, если они застрянут и получат странный результат в производстве.