esbuild.md 1.5 KB

esbuild

์†๋„๋ฅผ ์œ„ํ•ด ์ œ์ž‘๋œ ์ž๋ฐ”์Šคํฌ๋ฆฝํŠธ ๋ฒˆ๋“ค๋Ÿฌ ๋ฐ ์••์ถ• ๋„๊ตฌ. ๋” ๋งŽ์€ ์ •๋ณด: https://esbuild.github.io/.

  • ์ž๋ฐ”์Šคํฌ๋ฆฝํŠธ ์• ํ”Œ๋ฆฌ์ผ€์ด์…˜์„ ๋ฒˆ๋“ค๋กœ ๋ฌถ์–ด stdout์œผ๋กœ ์ธ์‡„:

esbuild --bundle {{๊ฒฝ๋กœ/๋Œ€์ƒ/ํŒŒ์ผ.js}}

  • stdin์—์„œ JSX ์• ํ”Œ๋ฆฌ์ผ€์ด์…˜ ๋ฒˆ๋“ค๋ง:

esbuild --bundle --outfile={{๊ฒฝ๋กœ/๋Œ€์ƒ/ํŒŒ์ผ.js}} < {{๊ฒฝ๋กœ/๋Œ€์ƒ/ํŒŒ์ผ.jsx}}

  • production ๋ชจ๋“œ์—์„œ ์†Œ์Šค๋งต์„ ์‚ฌ์šฉํ•˜์—ฌ JSX ์• ํ”Œ๋ฆฌ์ผ€์ด์…˜์„ ๋ฒˆ๋“ค๋กœ ๋ฌถ๊ณ  ์••์ถ•:

esbuild --bundle --define:{{process.env.NODE_ENV=\"production\"}} --minify --sourcemap {{๊ฒฝ๋กœ/๋Œ€์ƒ/ํŒŒ์ผ.js}}

  • ์‰ผํ‘œ๋กœ ๊ตฌ๋ถ„๋œ ๋ธŒ๋ผ์šฐ์ € ๋ชฉ๋ก์„ ์œ„ํ•ด JSX ์• ํ”Œ๋ฆฌ์ผ€์ด์…˜์„ ๋ฒˆ๋“ค๋กœ ๋ฌถ์Œ:

esbuild --bundle --minify --sourcemap --target={{chrome58,firefox57,safari11,edge16}} {{๊ฒฝ๋กœ/๋Œ€์ƒ/ํŒŒ์ผ.jsx}}

  • ํŠน์ • ๋…ธ๋“œ ๋ฒ„์ „์— ๋Œ€ํ•œ ์ž๋ฐ”์Šคํฌ๋ฆฝํŠธ ์• ํ”Œ๋ฆฌ์ผ€์ด์…˜ ๋ฒˆ๋“ค:

esbuild --bundle --platform={{node}} --target={{node12}} {{๊ฒฝ๋กœ/๋Œ€์ƒ/ํŒŒ์ผ.js}}

  • .js ํŒŒ์ผ์— JSX ๊ตฌ๋ฌธ์„ ํ™œ์„ฑํ™”ํ•˜๋Š” ์ž๋ฐ”์Šคํฌ๋ฆฝํŠธ ์• ํ”Œ๋ฆฌ์ผ€์ด์…˜์„ ๋ฒˆ๋“ค๋กœ ๋ฌถ์Œ:

esbuild --bundle app.js --loader:{{.js=jsx}} {{๊ฒฝ๋กœ/๋Œ€์ƒ/ํŒŒ์ผ.js}}

  • HTTP ์„œ๋ฒ„์—์„œ ์ž๋ฐ”์Šคํฌ๋ฆฝํŠธ ์• ํ”Œ๋ฆฌ์ผ€์ด์…˜์„ ๋ฒˆ๋“ค๋งํ•˜๊ณ  ์ œ๊ณต:

esbuild --bundle --serve={{port}} --outfile={{index.js}} {{๊ฒฝ๋กœ/๋Œ€์ƒ/ํŒŒ์ผ.js}}

  • ํŒŒ์ผ ๋ชฉ๋ก์„ ์ถœ๋ ฅ ํด๋”์— ๋ฒˆ๋“ค๋ง:

esbuild --bundle --outdir={{๊ฒฝ๋กœ/๋Œ€์ƒ/์ถœ๋ ฅ_ํด๋”}} {{๊ฒฝ๋กœ/๋Œ€์ƒ/ํŒŒ์ผ1 ๊ฒฝ๋กœ/๋Œ€์ƒ/ํŒŒ์ผ2 ...}}