Як я можу змусити компілятор 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.


Я думаю, що все ускладнюється, коли у вас конфігурація редактора / tsconfig / webpack config ... (просто розповідаю про моє відчуття ...)
Yarco,

Відповіді:


134

Використовуйте параметр --outDirна tsc (налаштований у File Watcher в IntelliJ)

З документації на командний рядок

--outDir DIRECTORY Redirect output structure to the directory.

Редагувати

Оскільки Typescript 1.5, це також можна встановити у tsconfig.jsonфайлі:

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

Це саме те, що я шукав! Велике спасибі, я не можу повірити, що я його раніше не бачив ...
TheGuyWithTheFace

3
Я вважаю, що тепер ви також можете використовувати --rootDirпрапор, щоб передати загальну папку кореня до транспілятора. Це не дозволить йому знайти загальну кореневу папку.
гузмонне

Чому цей параметр потрібно мати system або amd? Я не хочу, щоб збірка залежала від них.
Нікос

Окрім того, це, здається, зламає його у 2.0? stackoverflow.com/a/40149682/550975
Серж Саган

2
Це все ще працює? Схоже, це не працює при створенні веб-пакету.
mattnedrich

30

Або додайте "outDir": "build"у файл tsconfig.json


21
Примітка: "outDir": "build"йдеться в "compilerOptions"об’єкт вашого tsconfig.json, а не як властивість верхнього рівня.
Джеймі

7

Хоча ці відповіді правильні, ви повинні розглянути, чи дійсно ви просто хочете приховати .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 файл.


2
Я знаю, що це час від часу, але мені було цікаво, чи є перевага в тому, щоб не використовувати папки для збирання чи ви просто пропонували альтернативу?
Theaceofthespade

1
@theaceofthespade Це корисно, якщо ви хочете включити або прочитати файли у вихідній папці щодо __dirname. (Наприклад, .graphqlфайл схеми)
janispritzkau

3

Якщо ви хочете зіставити структуру каталогів папки програми / скриптів у 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, як це робити з компілятором?
Нітзан Томер

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

  • Файл -> Налаштування -> Набір тексту
  • Перекладач вузлів: Ваш 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-typecript і мій tsconfig.json виглядає приблизно так:

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

-1

Що стосується Grunt, на даний момент, щоб зберегти структуру проекту папок розробників у виробництві та не отримати несподіваний результат після складання файлів, зверніться до параметра:

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

Дивіться rootDir варіант в офіційних документах .

Я сподіваюся, що це допоможе комусь, якщо вони застрягнуть і отримають дивний результат у виробництві.

Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.