ฉันจะให้คอมไพเลอร์ typescript ส่งออก js ที่คอมไพล์ไปยังไดเร็กทอรีอื่นได้อย่างไร


119

ฉันค่อนข้างใหม่กับ 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


ฉันคิดว่าสิ่งต่าง ๆ จะซับซ้อนเมื่อคุณมี Editor Configuration / 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แฟล็กเพื่อส่งผ่านโฟลเดอร์รูททั่วไปไปยังทรานสไพเลอร์ได้ เพื่อหลีกเลี่ยงไม่ให้พบโฟลเดอร์รากทั่วไป
guzmonne

ทำไมตัวเลือกนี้จึงต้องเป็นระบบหรือเอเอ็มดี? ฉันไม่ต้องการให้งานสร้างขึ้นอยู่กับพวกเขา
Nikos

ยกเว้นสิ่งนี้ดูเหมือนจะทำลายมันใน 2.0? stackoverflow.com/a/40149682/550975
Serj Sagan

3
ยังใช้งานได้หรือไม่ ดูเหมือนจะไม่ทำงานเมื่อสร้างผ่าน webpack
mattnedrich

30

หรือเพิ่มลง"outDir": "build"ในไฟล์ tsconfig.json


21
หมายเหตุ: "outDir": "build"ไปใน"compilerOptions"ออบเจ็กต์ของ tsconfig.json ของคุณไม่ใช่เป็นคุณสมบัติระดับบนสุด
Jamie

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 Compiler แล้วจะทำอย่างไรกับคอมไพเลอร์
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

  • ไฟล์ -> การตั้งค่า -> typescript
  • ล่ามโหนด: เส้นทางการติดตั้ง 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 อย่างเป็นทางการ

ฉันหวังว่ามันจะช่วยใครสักคนหากพวกเขาติดขัดและได้รับผลงานแปลก ๆ ในการผลิต

โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.