TypeScript

Intro

  • JavaScript ๋Œ€์ฒด ์–ธ์–ด์˜ ํ•˜๋‚˜๋กœ์จ, JS์˜ ์ƒ์œ„ํ™•์žฅ(superset)

  • ES6์˜ ์ƒˆ๋กœ์šด ๊ธฐ๋Šฅ๋“ค์„ ์‚ฌ์šฉํ•˜๊ธฐ ์œ„ํ•ด, Babel๊ณผ ๊ฐ™์€ ๋ณ„๋„ ํŠธ๋žœ์ŠคํŒŒ์ผ๋Ÿฌ๋ฅผ ์‚ฌ์šฉํ•˜์ง€ ์•Š์•„๋„ ES6์˜ ์ƒˆ๋กœ์šด ๊ธฐ๋Šฅ์„ JS Engine(Node, browser...)์—์„œ ์‹คํ–‰๊ฐ€๋Šฅ

  • ECMA์˜ ํ‘œ์ค€์„ ๋”ฐ๋ผ๊ฐˆ ์ˆ˜ ์žˆ๋Š” ์ข‹์€ ์ˆ˜๋‹จ.

์žฅ์ 

  • ์ •์ ํƒ€์ž…

    • JS๋Š” type์„ ์‚ฌ์ „์— ํƒ€์ž…์„ ์ง€์ •ํ•˜์ง€ ์•Š๋Š”๋‹ค.

      (๋Ÿฐํƒ€์ž„์—์„œ ์—๋Ÿฌ ๋ฐœ์ƒ๊ฐ€๋Šฅ์„ฑ ๋†’์Œ)

    • TS๋Š” ์ •์ ํƒ€์ž…์„ ์ง€์›ํ•˜๋ฏ€๋กœ ์ปดํŒŒ์ผ ๋‹จ๊ณ„์—์„œ ์˜ค๋ฅ˜๋ฅผ ํฌ์ฐฉํ•  ์ˆ˜ ์žˆ๋‹ค.

    • ๋Œ€๊ทœ๋ชจ Application ๊ฐœ๋ฐœ ์šฉ์ด (์‹ค์ˆ˜ ๋ฐฉ์ง€๋ฅผ ํ•˜๋‹ˆ๊นŒ)

  • ๊ฐœ๋ฐœ ๋„๊ตฌ์˜ ์ง€์›

    • IDE(ํ†ตํ•ฉ ๊ฐœ๋ฐœ ํ™˜๊ฒฝ) ํฌํ•จ ๋‹ค์–‘ํ•œ ๋„๊ตฌ ์ง€์›

    • ํƒ€์ž…์ •๋ณด๋ฅผ ์ œ๊ณตํ•จ์œผ๋กœ์จ, ํƒ€์ž…์ฒดํฌ, ์ž๋™์™„์„ฑ๊ธฐ๋Šฅ, code assist...๋“ฑ์„ ์ง€์›๋ฐ›์„ ์ˆ˜ ์žˆ๋‹ค๋Š” ์žฅ์ ์ด ์žˆ๋‹ค.

  • ๊ฐ์ฒด์ง€ํ–ฅ ํ”„๋กœ๊ทธ๋ž˜๋ฐ ์ง€์›

    • class, interface, module๋“ฑ ๊ฐ•๋ ฅํ•œ ๊ธฐ๋Šฅ์„ ์ œ๊ณตํ•˜๋ฉฐ ์ˆœ์ˆ˜ ๊ฐ์ฒด ์ง€ํ–ฅ ์ฝ”๋“œ๋ฅผ ์ž‘์„ฑํ•  ์ˆ˜ ์žˆ๋‹ค.

  • ํฌ๋กœ์Šค ํ”Œ๋žซํผ ์ง€์›

    • JS๊ฐ€ ์‹ค์ƒ๋˜๋Š” ๋ชจ๋“  ํ”Œ๋žซํผ์—์„œ ์‚ฌ์šฉ๊ฐ€๋Šฅ

  • DOM์ œ์–ด

  • ์ตœ์‹  ECMAScript ์ง€์›

  • JS๋ผ์ด๋ธŒ๋Ÿฌ๋ฆฌ์™€์˜ ํŽธ๋ฆฌํ•œ ์‚ฌ์šฉ

  • ๊ฐœ๋ฐœํ™˜๊ฒฝ

    • Node.js์„ค์น˜

      • Node.js๊ฐ€ ์„ค์น˜๋œ ํ™˜๊ฒฝ์—์„œ TS๋ฅผ ๊ตฌ๋™์‹œํ‚ฌ์ˆ˜์žˆ๋‹ค.

    • VSCode (ํ˜น์€ Webstorm)

      • ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ ๊ธฐ๋Šฅ ๊ธฐ๋ณธ ๋‚ด์žฅ๋˜์–ด์žˆ์Œ.

      • TSํŒŒ์ผ(.ts, .tsconfig.json,..)์ธ์‹ํ•จ.

      • ์ฝ”๋“œ ๊ฒ€์‚ฌ, ๋น ๋ฅธ ์ˆ˜์ •, ์‹คํ–‰ ๋ฐ ๋””๋ฒ„๊น… ๋“ฑ ๋‹ค์–‘ํ•œ ๊ธฐ๋Šฅ ๋ฐ”๋กœ ์‚ฌ์šฉ๊ฐ€๋Šฅ.

      • ๋‹จ ์ปดํŒŒ์ผ๋Ÿฌ๋Š” ๋ณ„๋„ ์„ค์น˜(์ „์—ญ์„ค์น˜ ์ง„ํ–‰)

        • typescript ์ปดํŒŒ์ผ๋Ÿฌ๋Š” node.js ํ”„๋กœ๊ทธ๋žจ

          npm install typescript -g
        • ์„ค์น˜ํ›„, ์ปค๋งจ๋“œ ์ฐฝ์— tsc [ํŒŒ์ผ๋ช…].ts ๋ผ๊ณ  ํ•˜๋ฉด ์ปดํŒŒ์ผ๋œ ๊ฒฐ๊ณผ๋ฌผ์ด ๋‚˜์˜ด

      • ํŒŒ์ผ๊ฒฝ๋กœ ๋ณด์ด๊ธฐ ์„ค์ •: [ํŒŒ์ผ] - [๊ธฐ๋ณธ์„ค์ •] - ์„ค์ • - [Breadcrumbs: Enabled] ์ฒดํฌ

    • ์ปดํŒŒ์ผ๋Ÿฌ ์˜ต์…˜์„ค์ •

      • ์˜ต์…˜์„ค์ • ์—†์ด ์ปดํŒŒ์ผ์„ ๊ฑฐ์น˜๋ฉด ES5 ํ˜•ํƒœ ์ฝ”๋“œ๋กœ ์ปดํŒŒ์ผ์ด๋œ๋‹ค.

      • ํŠน์ •๋ฒ„์ „์œผ๋กœ ์‚ฌ์šฉํ•˜๊ณ ์‹ถ์„๋•Œ ์‚ฌ์šฉํ•˜๋Š” ์˜ต์…˜: ---target

        tsc hello.ts --target es6
      • ๊ธฐ๋Šฅ์ ์ฝ”๋“œ (์˜ˆ: Promise, Promise๋Š” es6 ๋ฒ„์ „ ์ด์ƒ) --lib

        • ์ปดํŒŒ์ผํ•˜๋ฉด err: Promise๋ฅผ ์ฐพ์„์ˆ˜ ์—†๋‹ค๋Š” error

        • Promise๋ฅผ ์ง€์›ํ•˜๊ธฐ ์œ„ํ•œ ๋ณ„๋„์˜ polyfill์ด ํ•„์š”ํ•˜๋‹ค.

          tsc hello.ts --lib es5,es2015.promise,es2015.iterable,dom
          tsc hello ts --lib es2015,dom <!--์ถ•์•ฝํ˜•-->
        • dom: console ์‚ฌ์šฉํ•˜๊ธฐ ์œ„ํ•ด ์ถ”๊ฐ€

      • module๊ด€๋ จ ์˜ต์…˜ --module

        • util.tsํŒŒ์ผ์—์„œ ๋ชจ๋“ˆ์„ export ํ•ด์ฃผ๊ณ , hello.tsํŒŒ์ผ์—์„œ import๋กœ ๋ชจ๋“ˆ ๊ฐ€์ ธ์˜จ ๋‹ค์Œ compile์ง„ํ–‰

          tsc hello.ts --lib es2015,dom
        • ์ปดํŒŒ์ผ ๊ฒฐ๊ณผ, import๊ฐ€ require๋กœ ๋ณ€๊ฒฝ๋œ ๊ฒƒ์„ ํ™•์ธํ•  ์ˆ˜ ์žˆ์Œ.

        • ์ฆ‰ es5๋Š” ๊ธฐ๋ณธ์ ์œผ๋กœ commonJS์‹œ์Šคํ…œ์„ ๋”ฐ๋ฅด๊ณ  ์žˆ๋‹ค๋Š” ์ ์„ ์•Œ ์ˆ˜ ์žˆ๋‹ค.

        • ๋”ฐ๋ผ์„œ node๋กœ jsํŒŒ์ผ์„ ์‹คํ–‰์‹œํ‚ค๋ฉด ์‹คํ–‰์ด ๋œ๋‹ค.

        • target์˜ต์…˜์„ es6๋กœ ์ค˜๋ณด๊ธฐ

          tsc hello.ts --target es6 --lib es2015,dom
        • ์ปดํŒŒ์ผ ๊ฒฐ๊ณผ๊ฐ€ es6๋ฒ„์ „์ด๊ธฐ ๋•Œ๋ฌธ์— arrow function๋„ ๋ณด์ด๊ณ , import๊ฐ€ ์‚ฌ์šฉ๋œ ๊ฒƒ์ด ํ™•์ธ๋œ๋‹ค.

        • ๋‹จ, js๋ฅผ node.js๋กœ ์‹คํ–‰์‹œํ‚ค๋ คํ•˜๋ฉด syntax error๋ฅผ ๋ฟœ์–ด๋‚ธ๋‹ค.

          • ์™œ? target์€ es6์ง€๋งŒ ๋ชจ๋“ˆ ์‹œ์Šคํ…œ์€ commonJSํ˜•ํƒœ์ด๊ธฐ๋•Œ๋ฌธ

          • ํ•ด๊ฒฐ: module์˜ต์…˜์œผ๋กœ ํ•ด๊ฒฐ

            tsc hello.ts --target es6 --lib es2015,dom --module commonjs
      • ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ๋ฅผ ์‹คํ–‰ํ•  ๋•Œ๋งˆ๋‹ค, ์ด ์˜ต์…˜์„ ๋งค๋ฒˆ ํ„ฐ๋ฏธ๋„์— ์ž…๋ ฅํ•ด์„œ ์‹คํ–‰์‹œ์ผœ์•ผํ• ๊นŒ? Nope!!!!!!

        • compile ์„ค์ •ํ•  ์ˆ˜ ์žˆ๋Š” ๋ณ„๋„ ํŒŒ์ผ์ด ์žˆ์Œ(tsconfig.json)

        • compile ์˜ต์…˜์„ ์ง€์ •ํ•  ์ˆ˜ ์žˆ๊ณ  command๋ช…๋ น์„ ํ†ตํ•ด ์–ด๋–ค ์˜ต์…˜๋“ค์ด ์ ์šฉ๋˜์–ด์žˆ๋Š”์ง€๋„ ํ™•์ธํ•  ์ˆ˜ ์žˆ๋‹ค. showConfig

          tsc hello.ts --target es6 --lib es2015,dom --module commonjs --showConfig
        • configuration ํŒŒ์ผ์„ ์„ค์ •ํ•ด์„œ ๋งค๋ฒˆ ์˜ต์…˜์„ CLI์— ์ž…๋ ฅํ•˜์ง€ ์•Š์•„๋„ ๋˜๊ฒŒ๋” ํ•ด๋ณด์ž.

    • TypeScript ์ปดํŒŒ์ผ๋Ÿฌ ์„ค์ •ํŒŒ์ผ(tsconfig.json)

      • tsconfig.json (์„ค์ •) ํŒŒ์ผ์€ ํ”„๋กœ์ ํŠธ์˜ ์ตœ์ƒ๋‹จ ์œ„์น˜์— ์กด์žฌํ•˜๊ฒŒ๋จ

      • ์„ค์ •์„ ์ฃผ๊ฒŒ๋˜๋ฉด ์„ค์ •์— ์˜ํ•ด ์ปดํŒŒ์ผ๋˜๋ฉฐ, jsonํ˜•ํƒœ

      • ์ปดํŒŒ์ผํ•˜๋Š”๋ฐ ํ•„์š”ํ•œ ๋ฃจํŠธํŒŒ์ผ๊ณผ ์ปดํŒŒ์ผ๋Ÿฌ ์˜ต์…˜ ์„ค์ •

        • include :ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ ์ปดํŒŒ์ผ๋Ÿฌ์— ํฌํ•จ๋˜์–ด์งˆ ํŒŒ์ผ ๋ชฉ๋ก๋“ค

        • exclude: ์ œ์™ธ ๋ชฉ๋ก

          • ๋Œ€์ฒด๋กœ typescript๋Š” nodejs๊ธฐ๋ฐ˜์œผ๋กœ ๋งŒ๋“ค์–ด์ง„๋‹ค.

            npm init --y ๋กœ node project(pakage.json)๋ฅผ ๋งŒ๋“ค๊ณ  ์ƒ์„ฑ๋˜๋Š” node modules๋Š” typescript ์ปดํŒŒ์ผ ๋Œ€์ƒ์—์„œ ์ œ์™ธ

        • compilerOptions :์ปดํŒŒ์ผ๋Ÿฌ ์˜ต์…˜

          • ์˜ˆ

            • module

            • target

            • ๋“ฑ๋“ฑ

      • ์„ค์ • ํ›„์—๋Š” tsc๋งŒ ํ˜ธ์ถœํ•ด๋„ ํ˜„์žฌ dir๋ถ€ํ„ฐ ์ƒ์œ„ dir chain์„ ๋”ฐ๋ผ์„œ tsconfig.jsonํŒŒ์ผ์„ ๊ฒ€์ƒ‰

      • ์„ค์ •๋ฐ ์ปดํŒŒ์ผ ํ›„, browser์—์„œ ํ™•์ธํ•ด๋ณด๋ฉด ์›๋ณธํŒŒ์ผ์€ ๋ณด์ด์ง€ ์•Š๊ณ  ์ปดํŒŒ์ผ ๋œ jsํŒŒ์ผ๋งŒ ๋ณด์ธ๋‹ค. ๋งŒ์•ฝ ์›๋ณธํŒŒ์ผ(ts)์„ ๋ณด๊ณ ์‹ถ์„ ๊ฒฝ์šฐ ์„ค์ •์„ ์ถ”๊ฐ€ํ•˜์ž. "sourceMap": true

Last updated