- ํด๋น ์ ์ฅ์๋
๋ฆฌ์กํธ ์ปค์คํ ๊ฐ๋ฐ ํ๊ฒฝ ๋ณด์ผ๋ฌ ํ๋ ์ดํธ ์ ์ฅ์
๋ก์, react, webpack, babel, eslint ๋ฑ ๋ฆฌ์กํธ ํ๋ก์ ํธ๋ฅผ ์งํ ํ ๋ ๊ธฐ๋ณธ์ ์ผ๋ก ์ ํ ํด์ผ๋๋ ๊ฐ๋ฐ ํ๊ฒฝ์ ๊ตฌ์ถํ ์ ์ฅ์์ ๋๋ค. - ๊ธฐ๋ณธ์ ์ผ๋ก react v18, webpack v5, esbuild-loader v3 ๋ฑ
2023๋ 6์ ๊ธฐ์ค
์ต์ ๋ฒ์ ์ผ๋ก ๊ตฌ์ถ๋์ด ์์ต๋๋ค. - README ๋ฌธ์ ํ๋จ์๋ ์ฐธ๊ณ ๋ด์ฉ์ด๋ผ๋๊ฐ ๊ฐ์ธ์ ์ผ๋ก ๋ ์ถ๊ฐํ๋ฉด ์ข์ ๋ก๋/ํ๋ฌ๊ทธ์ธ ๋ด์ฉ๋ ์์ผ๋ ์ฐธ๊ณ ํ๋ฉด ์ข์ ๊ฒ ๊ฐ์ต๋๋ค.
- ๊ฐ์ ํ ๋ด์ฉ์ด ์๋ค๋ฉด issue ๋๋ Pull Request๋ ๋ฑ๋กํด์ฃผ์๋ฉด ๊ฐ์ฌ๋๋ฆฝ๋๋ค.
git clone https://github.com/ssi02014/react-dev-env-boilerplate.git
- ํด๋น ๋ ํฌ๋ ๋ค์ํ ํ๊ฒฝ์ ๋ง์ถฐ ๋ธ๋์น๊ฐ ๊ตฌ์ฑ๋์ด ์๋ค. ๊ธฐํธ์ ๋ง๊ฒ ์ฐธ๊ณ or ์ฌ์ฉํ๋ฉด ๋๋ค.
- ๋ง์ฝ,
esbuild-loader
๋ธ๋์น ์ฝ๋๋ฅผ ํ์ธํ๋ ค๋ฉด ์๋์ ์ ์ฐจ๋ฅผ ์งํํ๋ค.
git branch esbuild-loader
git checkout -m esbuild-loader
git pull origin esbuild-loader
- ํด๋น ๋ ํฌ๋
yarn
ํจํค์ง ๋งค๋์ ๋ฅผ ๊ธฐ๋ฐ์ผ๋ก ํจํค์ง๋ฅผ ๊ด๋ฆฌํ๊ณ ์๋ค. ๋ฐ๋ผ์ yarn์ผ๋ก ํจํค์ง๋ฅผ ์ค์นํ์.
yarn
or
yarn install
- ๊ฐ์ฅ ๊ธฐ๋ณธ์ ์ธ react, babel, typescript, eslint, prettier, jest, React Testing Library ์ ํ ๋ธ๋์น
์ ํ ๋ชฉ๋ก
- react v18
- typeScript
- webpack v5
- babel
- eslint
- prettier
- jest
- react testing library
- master Branch ์
ํ
์์ babel-loader๋์
esbuild-loader
๋ฅผ ์ ์ฉํด์ ๋น๋ ํ์์ ๊ฐ์์ํจ ๋ธ๋์น
์ ํ ๋ชฉ๋ก
- react v18
- typeScript
- webpack v5
- esbuild-loader
- eslint
- prettier
- esbuild-loader Branch ์
ํ
์์
jest
,react testing library
ํ ์คํธ ํ๊ฒฝ ์ถ๊ฐ ๋ธ๋์น - ํ
์คํธ ํ๊ฒฝ์ ์ํด
@babel/preset-typescript
,@babel/preset-env
,@babel/preset-react
๋ฐ babel ์ถ๊ฐ ์ ํ
์ ํ ๋ชฉ๋ก
- react v18
- typeScript
- webpack v5
- esbuild-loader
- eslint
- prettier
- jest
- react testing library
- jest๋ฅผ ์ํ babel ์ผ๋ถ ์ ์ฉ
- react-npm-deploy-boilerplate
- Design System์ ๊ฐ์ npm ์คํ์์ค ๋ฐฐํฌ์ ์ต์ ํ ๋ณด์ผ๋ฌ ํ๋ ์ดํธ ์ ์ฅ์
- React, rollup, Typescript, Storybook ๋ฑ์ผ๋ก ๊ตฌ์ฑ
- github actions๋ฅผ ์ด์ฉํ ์๋ ๋น๋ ๋ฐ ๋ฐฐํฌ ๊ตฌํ
- Storybook์ github page๋ก ๋ฐฐํฌํจ์ผ๋ก์จ ๋ฐ๋ชจ ํ์ด์ง๋ก์ ํ์ฉ
- react-vite-berry-boilerplate
- React, TypeScript, Vite, Yarn Berry๋ก ๊ตฌ์ฑํ ๋ฆฌ์กํธ ํ๋ก์ ํธ ๋ณด์ผ๋ฌ ํ๋ ์ดํธ ์ ์ฅ์
Vite
๋ฅผ ์ด์ฉํ ๋ฆฌ์กํธ(+ํ์ ์คํฌ๋ฆฝํธ) ํ๋ก์ ํธ ๊ตฌ์ฑ- Yarn Berry์
PlugโnโPlay(PnP)
์Zero-Install
์ ์ฉ
- esbuild-loader๋
๋ฉํฐ ์ค๋ ๋ ๊ธฐ๋ฐ
์ผ๋ก ๋์ํ๋ Go์ธ์ด๋ก ์์ฑ๋ ๋ก๋์ด๋ค. ๊ทธ๋์ ์ฑ๊ธ ์ค๋ ๋ ๊ธฐ๋ฐ์ธ ์๋ฐ์คํฌ๋ฆฝํธ๋ก ๋ง๋ค์ด์ง babel๋ณด๋ค ์ธ์ด๊ฐ ๋์ํ๋ ๋ณธ์ง์ ์ธ ์ฐจ์ด๋๋ฌธ์ ํผํฌ๋จผ์ค ์ธก๋ฉด์์ ์ฐจ์ด๊ฐ ํฌ๋ค. - kakao esbuild-loader ๋ฌธ์
๊ธฐ์กด babel-loader ๋น๋ ํ์
esbuild-loader ๋์ ํ ๋น๋ ํ์
- @svgr/webpack ํจํค์ง๋ svg๋ฅผ ๋ฆฌ์กํธ ์ปดํฌ๋ํธ ํ์์ผ๋ก ์ฌ์ฉํ ์ ์๊ฒ ๋ณํํด์ฃผ๋ ์นํฉ ๋ชจ๋์ด๋ค.
- https://react-svgr.com/
์์
import Star from './star.svg'
const Example = () => (
<div>
<Star />
</div>
)
- @svgr/webpack๋ฅผ ์ ์ฉํ๋ฉด ์ ์์ ์ฒ๋ผ svg๋ฅผ importํด์ ์ปดํฌ๋ํธ๋ก ํ์์ผ๋ก ์ฌ์ฉํ ์ ์๋ค.
- Create React App(CRA)๋ก ๋ง๋ ํ๋ก์ ํธ๋ font๋ฅผ preloadํ๋ ค๋ฉด
craco
์ ๊ฐ์ ๋ผ์ด๋ธ๋ฌ๋ฆฌ๋ฅผ ํ์ฉํด์preload-webpack-plugin
,webpack-font-preload-plugin
์ ์ ์ฉํ์ด์ผ ํ๋ค.- TMI: preload-webpack-plugin๋ webpack5๋ถํฐ ํธํ๋์ง ์์์ webpack-font-preload-plugin๋ฅผ ์ฌ์ฉํด์ผ ํจ
- ํ์ง๋ง, ํด๋น ๋ณด์ผ๋ฌ ํ๋ ์ดํธ๋
html-loader
๊ฐ ์ ์ฉ๋์ด ์๊ธฐ ๋๋ฌธ์ preload๋ฅผ ์ํ ํ๋ฌ๊ทธ์ธ์ ์ค์นํ์ง ์์๋ ๋๋ค.- CRA๋ html-loader๊ฐ ์ ์ฉ๋์ด์์ง ์๊ณ , html-webpack-plugin ๋ง ์ ์ฉ๋์ด ์์ด์ ์ด๋ฐ ์ฐจ์ด๊ฐ ์์.
- ์์ธํ ๋ด์ฉ์ ๋ธ๋ก๊ทธ: ์ปค์คํ ์นํฉ ํ๊ฒฝ์์ font preloadํ๋ฉด์ ๊ฒช์ ๋ฌธ์ ๊ณ ์ฐฐ ์ฐธ๊ณ
- ์ค์ ์ ์ฉ ๋ฐฉ๋ฒ์ ํฐํธ ํ์ผ๋ค์ด
src/assets/fonts
๊ฒฝ๋ก์ ์๋ค๊ณ ๊ฐ์ ํ๊ณ ,index.html
ํ์ผ์ ์๋์ฒ๋ผ ์์ฑํ๋ฉด ๋๋ค.
<head>
<!-- head -->
<link
rel="preload"
href="/src/assets/fonts/Pretendard-Medium.subset.woff"
as="font"
type="font/woff"
crossorigin
/>
</head>
- ํ์ฌ ์ํ์์
build
ํด๋ณด๊ณ ํ์ธํด๋ณด๋ฉด ์ ๋๋ก๋ ๊ฒฝ๋ก๋ก ํ์ผ์ ๊ฐ์ ธ์ค๋ ๊ฒ์ ํ์ธํ ์ ์๋ค.
- Sass๋ Syntactically Awesome Style Sheets์ ์ฝ์๋ก, CSS์ ํ์ฅ๋ ๋ฌธ๋ฒ์ ์ ๊ณตํ๋ CSS ์ ์ฒ๋ฆฌ๊ธฐ(preprocessor)๋ค.
- Sass๋ ๋น๋ ์์ CSS ํ์ผ๋ก ์ปดํ์ผ๋์ผ ํ๋ค. ๋ฐ๋ผ์, webpack์์ Sass ํ์ผ์ ์ฝ๊ณ , CSS ํ์ผ๋ก ์ปดํ์ผํ์ฌ ๋ฒ๋ค๋งํ๋ ค๋ฉด sass-loader๋ฅผ ์ถ๊ฐํด์ผ ํฉ๋๋ค.
ํจํค์ง ์ค์น
yarn add -D sass sass-loader
webpack ์ ํ
[MiniCssExtractPlugin.loader, 'css-loader', 'sass-loader']
์ ๊ฐ์ด ๋ฐฐ์ด์ ๋ฃ์๋๋ฐ ์ฌ๊ธฐ์ ์์๊ฐ ์ค์ํ๋ค.- ์ด๋ ๋ฐฐ์ด ๋ง์ง๋ง ์์๋ถํฐ ๋ก๋๊ฐ ์ ์ฉ๋๊ธฐ ๋๋ฌธ์ธ๋ฐ, sass-loader๋ฅผ ํตํด์ ๋จผ์ sassํ์ผ์ css๋ก ์ปดํ์ผ ํ ํ, css-loader๊ฐ ์ปดํ์ผ ๋ css ํ์ผ์ ๋ชจ๋๋ก ์ฝ์ด๋ค์ธ ๋ค์, MiniCssExtractPlugin.loader ๊ฐ ๋ณ๋์ ํ์ผ๋ก ์ถ์ถ๋ css ํ์ผ์ ๋ก๋ํ๊ธฐ ๋๋ฌธ์ด๋ค.
- ๋ฐฐ์ด ์์๋ฅผ ์ ํํ๊ฒ ์์ฑํ์ง ๋ก๋๊ฐ ์ ์์ ์ผ๋ก ์๋ํ์ง ์์ ์๋ฌ๊ฐ ๋ฐ์ํ ์ ์์ผ๋..๐ฑ ์์๋ฅผ ๊ผญ ๋ง์ถฐ์ฃผ์!
module.exports = {
module: {
rules: [
// ...webpack rules
{
test: /\.(sa|sc|c)ss$/i, // scss, sass, css ํ์ผ ๋งค์นญ
use: [MiniCssExtractPlugin.loader, 'css-loader', 'sass-loader'], // sass-loader ์ถ๊ฐ
},
]
}
}
scssํ์ผ ์์ฑ ํ ์ ์ฉ
// style.scss
body {
font-family: Pretendard;
background-color: rgb(192, 249, 230);
}
// App.tsx
import './style.scss';
import './style2.css';
function App() {
// ...
}
export default App;
- webpack-bundle-analyzer๋ webpack ๋ฒ๋ค๋ง ๊ฒฐ๊ณผ๋ฅผ ์๊ฐํํ์ฌ ๋ฒ๋ค๋ง ํฌ๊ธฐ๋ฅผ ํ์ธํ ์ ์๋๋ก ๋์์ฃผ๋ ๋๊ตฌ๋ค.
- webpack-bundle-analyzer๋ webpack์ผ๋ก ๋ฒ๋ค๋ง๋ ๊ฒฐ๊ณผ๋ฌผ์ ์๊ฐ์ ์ผ๋ก ํ์ ํ์ฌ ๋ฒ๋ค๋ง ํฌ๊ธฐ๋ฅผ ์ค์ด๋ ๋ฐ ๋์์ ์ค ์ ์๋ค.
- webpack-bundle-analyzer
ํจํค์ง ์ค์น
yarn add -D webpack-bundle-analyzer
webpack ์ ํ
const BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin;
module.exports = {
plugins: [
// webpack plugins...
new BundleAnalyzerPlugin({
analyzerMode: "static", // ๋ถ์ ํ์ผ html์ buildํด๋์ ์ ์ฅ
reportFilename: 'bundle-report.html', // ๋ถ์ ํ์ผ ๋ณด๊ณ ์ ์ด๋ฆ(์์ ๋กญ๊ฒ ์ง์ )
openAnalyzer: false, // ๋ถ์ ํ์ผ์ ์คํ ์ ์๋์ผ๋ก ์ด์ง ์๋๋ค.
generateStatsFile: true, // ๋ถ์ ํ์ผ์ json์ผ๋ก ์ ์ฅํ๋ค.
statsFilename: "bundle-report.json", // ๋ถ์ ํ์ผ json ํ์ผ ์ด๋ฆ (์์ ๋กญ๊ฒ ์ง์ )
})
]
}
package.json ์ ํ
{
// ...
"scripts": {
// ...
"preanalyze": "yarn build:prod",
"analyze": "webpack-bundle-analyzer ./build/bundle-report.json --default-sizes gzip",
}
}
yarn analyze ์คํ
- yarn analyze ์คํ ์ ๋น๋ ํ ๋ถ์ ์งํ
yarn analyze