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ファイルと同じディレクトリ構造を維持する方法は気に入っていますが、VCSで.jsファイルを追跡したくないため、すべての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があると状況が複雑になると思います...(ちょうど私の気持ちを伝えています...)
Yarco

回答:


134

--outDirtsc のオプションを使用(IntelliJのFile Watcher内で構成)

コマンドラインのドキュメントから

--outDir DIRECTORY Redirect output structure to the directory.

編集する

Typescript 1.5以降、これは次のtsconfig.jsonファイルでも設定できます。

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

これがまさに私が探していたものです!
どうも

3
これで、--rootDirフラグを使用して共通のルートフォルダーをトランスパイラーに渡すことができるようになったと思います。これにより、共通のルートフォルダーを見つける必要がなくなります。
guzmonne 2015年

なぜこのオプションはsystemまたはamdである必要があるのですか?ビルドをそれらに依存させたくありません。
Nikos

を除いて、これは2.0でそれを壊すように見えるのですか?stackoverflow.com/a/40149682/550975
Serj Sagan 2017

2
これはまだ機能しますか?Webpackを使用してビルドする場合は機能しないようです。
mattnedrich 2017年

30

または、"outDir": "build"tsconfig.jsonファイルに追加します


21
注:トップレベルプロパティとしてではなく、tsconfig.json "outDir": "build""compilerOptions"オブジェクトに入ります。
ジェイミー

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)"
    }
}

上記は、対応する.tsファイルが存在する.jsファイルを非表示にします。


2
私はこれが昔からあることを知っていますが、興味がありました。ビルドフォルダーを使用しないことには利点がありますか、それとも代替案を提供しているだけですか?
theaceofthespade

1
@theaceofthespadeを基準にしてソースフォルダー内のファイルを含めたり読み取ったりする場合に便利です__dirname。(たとえば.graphqlスキーマファイル)
janispritzkau

3

jsでapp / scriptsフォルダーのディレクトリ構造をマップする場合は、File Watcherに次の設定を使用することをお勧めします。

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 2015

3

Intellijユーザー、Typescriptを複数の出力ディレクトリにコンパイル

Intellijユーザーにとって、これは役立つかもしれません。これが、組み込みのTypescript Compilerを使用して機能させる方法でした。

環境情報

  • Windows 7
  • NPMバージョン1.7.3 を使用する Typescript
  • Intellij 14
  • ES6
  • RequireJSの使用

ディレクトリ構造の例

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セットアップ

  • ファイル->設定-> Typescript
  • 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

入力するとnpm run startすべてがに出力されるように、package.jsonをこのように設定します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-typescript拡張子を持つAtomを使用しており、私のtsconfig.jsonは次のようになります。

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

-1

Gruntについては、現在、devフォルダーのプロジェクト構造を本番環境に保存し、ファイルのコンパイル後に予期しない結果が発生しないようにするには、オプションを参照してください。

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

公式のgrunt-tsドキュメントのrootDirオプションを参照してください。

彼らが行き詰まり、本番環境で奇妙な結果を得る場合、それが誰かを助けることを願っています。

弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.