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.

Я надеюсь, что это поможет кому-то, если они застрянут и получат странный результат в производстве.