Как я могу заставить компилятор Typescript выводить скомпилированные js в другой каталог?


119

Я новичок в TypeScript, и сейчас у меня есть файлы .ts в нескольких местах по структуре моего проекта:

app/
 |-scripts/
    |-app.ts
    |
    |-classes/
    |  |-classA.ts
    |  |-classB.ts
    |  
    |-controllers/
    |  |-controllerA.ts
    |  |-controllerB.ts
    |  
    |-otherStuff/
       |-otherstuffA.ts

Прямо сейчас, когда мои файлы компилируются, они компилируются в тот же каталог, что и файлы .ts:

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.


Я думаю, что все усложняется, когда у вас есть Editor Configuration / tsconfig / webpack config ... (просто рассказываю о своих
чувствах

Ответы:


134

Используйте параметр --outDirtsc (настраивается в наблюдателе файлов в IntelliJ)

Из документации командной строки

--outDir DIRECTORY Redirect output structure to the directory.

редактировать

Начиная с Typescript 1.5, это также можно установить в tsconfig.jsonфайле:

"compilerOptions": {
    "outDir": "DIRECTORY"
    ...

Это именно то, что я искал! Большое спасибо, я не могу поверить, что не видел этого раньше ...
TheGuyWithTheFace

3
Я считаю, что теперь вы также можете использовать этот --rootDirфлаг для передачи общей корневой папки транспилятору. Это не позволит ему найти общую корневую папку.
guzmonne

почему эта опция должна быть system или amd? Я не хочу, чтобы сборка зависела от них.
Никос

За исключением того, что это, кажется, сломает его в 2.0? stackoverflow.com/a/40149682/550975
Серж Саган,

2
Это все еще работает? Кажется, что это не работает при сборке через webpack.
mattnedrich

30

Или добавьте "outDir": "build"в файл tsconfig.json


21
Примечание: "outDir": "build"входит в "compilerOptions"объект вашего tsconfig.json, а не как свойство верхнего уровня.
Джейми

7

Хотя эти ответы верны, вам следует подумать, действительно ли вы просто хотите скрыть свои файлы .js из своей среды IDE .

В Visual Studio Code перейдите к File > Preferences > Settingsили свой .vscode\settings.jsonфайл и введите:

"files.exclude": {
    "**/.git": true,
    "**/.DS_Store": true,
    "**/*.js" : {
        "when": "$(basename).ts"
    },
    "**/*.js.map": {
        "when": "$(basename)"
    }
}

Приведенное выше скрывает файлы .js, для которых существует соответствующий файл .ts.


2
Я знаю, что это было давно, но мне было любопытно, есть ли преимущество в том, чтобы не использовать папки сборки, или вы просто предлагали альтернативу?
theaceofthespade

1
@theaceofthespade Это полезно, если вы хотите включить или прочитать файлы в исходной папке относительно __dirname. (Например, .graphqlфайл схемы)
janispritzkau

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

1
Это действительно решает проблему с файловым наблюдателем, но, поскольку эта функция устарела и заменена компилятором TypeScript, как это сделать с компилятором?
Nitzan Tomer

3

Пользователи Intellij, компилируйте 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

  • Файл -> Настройки -> Машинопись
  • Node Interpreter: ваш путь установки NodeJS
  • Версия компилятора: обычно находится по адресу C:\yourUserName\AppData\Roaming\npm\node_modules\typescript\lib
  • Параметры командной строки: -m amd -t ES6 -outDir E:\myapp\js
  • Отметьте компилировать только главный файл и укажите его на свой входной файл. E:\myapp\ts\main.tsЕсли этот флажок не установлен, все ваши файлы будут пытаться выводить на ваш путь outDir.

введите описание изображения здесь


3

Я настраиваю 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"
  ]
}

1

Я использую Atom с расширением atom-typescript, и мой tsconfig.json выглядит так:

{
  "compilerOptions": {
    "outDir":"js"
  }
}

-1

Что касается Grunt, в настоящее время, чтобы сохранить структуру проекта папки dev в производственной среде и не получить неожиданный результат после компиляции файлов, пожалуйста, обратитесь к опции:

compilerOptions: { 
 rootDir: 'devFolder'
 // ...
}

См. RootDir в официальной документации grunt-ts.

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

Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.