如何获取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。


我认为当您使用编辑器配置/ tsconfig / webpack配置...时,事情变得复杂了(只是告诉我的感觉...)
Yarco

Answers:


134

使用--outDirtsc上的选项(在IntelliJ中的File Watcher中配置)

从命令行文档

--outDir DIRECTORY Redirect output structure to the directory.

编辑

从Typescript 1.5开始,这也可以在tsconfig.json文件中设置:

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

这正是我想要的!非常感谢,我简直不敢相信...
TheGuyWithTheFace 2014年

3
我相信,现在您还可以使用该--rootDir标志将公用的根文件夹传递给转换器。这样可以避免找到公用的根文件夹。
guzmonne 2015年

为什么此选项需要为system或amd?我不希望构建依赖于它们。
Nikos

除了,这似乎在2.0中打破了它?stackoverflow.com/a/40149682/550975
Serj Sagan

2
这仍然有效吗?通过webpack构建时,它似乎不起作用。
mattnedrich

30

或者,添加"outDir": "build"到tsconfig.json文件


21
注意:放在tsconfig.json "outDir": "build""compilerOptions"对象中,而不是作为顶级属性。
杰米

7

尽管这些答案是正确的,但您应该考虑是否实际上只是想从IDE中隐藏.js文件

在Visual Studio Code中,转到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文件夹的目录结构,建议对文件监视程序使用以下设置:

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设置

  • 文件->设置->打字稿
  • 节点解释器:您的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

我使用具有atomic-typescript扩展名的Atom和我的tsconfig.json看起来像这样:

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

-1

关于Grunt,目前要将您的dev文件夹项目结构保存在生产环境中,并且在文件编译后不会出现意外结果,请参考以下选项:

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

请参阅官方grunt-ts文档中的rootDir选项。

我希望如果有人卡住并在生产中取得怪异的结果,它将对他们有所帮助。

By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.