๐Ÿ“ฆ webpack์€ ๋ฌด์—‡์ธ๊ฐ€?

๊ถŒ๊ทœ๋ฆฌยท2024๋…„ 1์›” 22์ผ
0

๐Ÿ‘ฉ๐Ÿปโ€๐Ÿ’ปFrontEnd

๋ชฉ๋ก ๋ณด๊ธฐ
2/29
post-thumbnail

๐Ÿ“Œ ์—ฌ๋Š” ๋ง

webpack.. webpa..ck.. ๋Œ€๊ฐ• ๋ชจ๋“ˆ์„ ๋ฌถ์–ด์ฃผ๋Š” ์—ญํ• ์„ ํ•˜๋Š” ํ”„๋ ˆ์ž„์›Œํฌ์ธ ๊ฒƒ๋งŒ ์•Œ๊ณ  ์ž์„ธํžˆ๋Š” ๋ชจ๋ฅด๊ธฐ ๋•Œ๋ฌธ์— ๊ธฐ๋กํ•˜๊ธฐ!

(1) webpack์ด๋ž€?

webpack์€ ์—ฌ๋Ÿฌ๊ฐ€์ง€ ํŒŒ์ผ์„ ํ•˜๋‚˜์˜ ํŒŒ์ผ(๋ฒˆ๋“ค)๋กœ ๋ฌถ์–ด์ฃผ๋Š” ๋ชจ๋“ˆ ๋ฒˆ๋“ค๋Ÿฌ์ด๋‹ค.
HTML, CSS, JS, Image ๋“ฑ ํŒŒ์ผ์˜ ์˜์กด์„ฑ ๊ด€๊ณ„๋ฅผ ํŒŒ์•…ํ•˜์—ฌ ์••์ถ•ํ•ด์ฃผ๋Š” ์ž‘์—…์ด ๋ชจ๋“ˆ ๋ฒˆ๋“ค๋ง์ด๋‹ค.

webpack์˜ ์žฅ์ ์€? ๐Ÿค”

  • ๋กœ๋”ฉ ์†๋„ ๊ฐœ์„ 
  • ์›นํŽ˜์ด์ง€๋ฅผ ์ƒˆ๋กœ๊ณ ์นจํ•˜์ง€ ์•Š์•„๋„ ๋ณ€๊ฒฝ ์‚ฌํ•ญ ์ฆ‰์‹œ ๋ฐ˜์˜ ๊ฐ€๋Šฅ
  • ํŒŒ์ผ ๋ณ€๊ฒฝ ์‹œ, ์ž๋™์œผ๋กœ ๋ฒˆ๋“ค๋ง
  • ์ฝ”๋“œ๋ฅผ ๋ถ„ํ• ํ•˜์—ฌ, ์ดˆ๊ธฐ ๋กœ๋”ฉ ์†๋„ ๊ฐœ์„  = SPA ๊ฐœ์„  ๋ฐฉ์•ˆ์ธ Code Splitting
  • ํ•„์š”ํ•œ ์ฝ”๋“œ๋งŒ ๋กœ๋”ฉํ•˜์—ฌ ์‚ฌ์šฉ์ž ๊ฒฝํ—˜ ํ–ฅ์ƒ

(2) webpack ํ•ต์‹ฌ ๊ฐœ๋…

> npx webpack --help์„ ํ†ตํ•ด ์˜ต์…˜์˜ ์“ฐ์ž„์„ ์•Œ์•„๋ณด์ž.

โญ Entry

โ€”-entry <value...>
Entry๋Š” ๋ชจ๋“ˆ์˜ ์‹œ์ž‘์ ์ด๋‹ค.
์œ„์˜ ๋ช…๋ น์–ด๋กœ ๋ชจ๋“ˆ์˜ ์‹œ์ž‘์ ์„ ์„ค์ •ํ•  ์ˆ˜ ์žˆ์œผ๋ฉฐ Entry point๊ฐ€ ์ง,๊ฐ„์ ‘์ ์œผ๋กœ ์˜์กดํ•˜๋Š” ๋‹ค๋ฅธ ๋ชจ๋“ˆ๊ณผ ๋ผ์ด๋ธŒ๋Ÿฌ๋ฆฌ๋ฅผ ์ฐพ์•„๋‚ธ๋‹ค.

โญ Output

-o, --output-path <value>
๋ชจ๋“  ๋ชจ๋“ˆ์„ ํ•˜๋‚˜๋กœ ํ•ฉ์ณ์„œ ์ €์žฅํ•˜๋Š” ๊ฒฝ๋กœ๋ฅผ ์„ค์ •ํ•œ๋‹ค.
์ฆ‰, ์›นํŒฉ์œผ๋กœ ์ƒ์„ฑ๋˜๋Š” ํŒŒ์ผ์˜ ์œ„์น˜๋ฅผ ์„ค์ •ํ•œ๋‹ค.

โญ Loaders

๋ชจ๋“ˆ์˜ ์†Œ์Šค ์ฝ”๋“œ์— ๋ณ€๊ฒฝ ์‚ฌํ•ญ์„ ์ ์šฉํ•˜๋Š” ์—ญํ• ์„ ํ•œ๋‹ค.

(+) ์›นํŒฉ์€ JS๋กœ ๋งŒ๋“  ๋ชจ๋“ˆ ๋ฟ ์•„๋‹ˆ๋ผ, CSS, HTML, Image๋“ฑ ๋ชจ๋“  ๊ฒƒ์„ ๋ชจ๋“ˆ์ฒ˜๋Ÿผ ๋‹ค๋ฃฐ ์ˆ˜ ์žˆ๋‹ค. ์ด๊ฒƒ์„ ๊ฐ€๋Šฅํ•˜๊ฒŒ ๋งŒ๋“ค์–ด์ฃผ๋Š” ๊ฒƒ์ด ๋กœ๋”์ด๋‹ค. ์ฆ‰, ๋ชจ๋“  ์ž์›์„ ๋ชจ๋“ˆ๋กœ ๋ถˆ๋Ÿฌ์˜ค๋Š” ๊ฒƒ์ด๋‹ค.

โญ Plugins

๋กœ๋”๊ฐ€ ์ˆ˜ํ–‰ํ•  ์ˆ˜ ์—†๋Š” ๋‹ค์–‘ํ•œ ๊ธฐ๋Šฅ์„ ์ˆ˜ํ–‰ํ•œ๋‹ค.

๋‹ค์‹œ ๋งํ•˜์ž๋ฉด, ๋กœ๋”๊ฐ€ ํŒŒ์ผ(๋ชจ๋“ˆ) ๋‹จ์œ„๋กœ ๊ธฐ๋Šฅ์„ ์ฒ˜๋ฆฌํ•˜๋Š” ๋ฐ˜๋ฉด, ํ”Œ๋Ÿฌ๊ทธ์ธ์€ ์ตœ์ข…์ ์œผ๋กœ ๋ฒˆ๋“ค๋œ ๊ฒฐ๊ณผ๋ฌผ์„ ๊ฐ€๊ณตํ•  ๋•Œ ์‚ฌ์šฉํ•œ๋‹ค.


profile
๊ธฐ๋ก์žฅ ๐Ÿ“

0๊ฐœ์˜ ๋Œ“๊ธ€