일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
- react
- JavaScript
- Servlet
- JS
- TypeScript
- 그럼에도 불구하고
- CSS
- react-router-dom
- coding
- redux
- max-width
- node.js
- 코드업
- cleancode
- HTML
- 프론트엔드
- @media
- 변수
- 코딩테스트
- github
- 자바문제풀이
- media query
- frontend
- 자바
- git
- java
- webpack
- 반응형 페이지
- 그럼에도불구하고
- node
- Today
- Total
그럼에도 불구하고
[Webpack] 웹팩의 4가지 주요 속성 본문
오늘은 웹팩의 4가지 주요 속성에 대해 알아보겠습니다.
1. Entry
2. Output
3. Loader
4. Plugin
[ Entry ]
entry 속성은 웹팩에서 웹 자원을 변환하기 위해 필요한 최초 진입점이자 자바스크립트 파일 경로입니다.
1 2 3 4 | // webpack.config.js module.exports = { entry: './src/index.js' } | cs |
위 코드는 웹팩을 실행했을 때 src 폴더 밑의 index.js를 대상으로 웹팩이 빌드를 수행하는 코드입니다.
[ Entry 파일에 어떤 것이 들어가야 하는가 ]
entry 속성에 지정된 파일에는 웹 애플리케이션의 전반적인 구조와 내용이 담겨 있어야 합니다. 웹팩이 해당 파일을 가지고 웹 애플리케이션에서 사용되는 모듈들의 연관 관계를 이해하고 분석하기 때문에 애플리케이션을 동작시킬 수 있는 내용들이 담겨 있어야 합니다.
예를 들어, 블로그 서비스를 웹팩으로 빌드한다고 했을 때 코드의 모양은 아래와 같을 수 있습니다.
1 2 3 4 5 6 7 8 9 10 11 12 | // index.js import LoginView from './LoginView.js'; import HomeView from './HomeView.js'; import PostView from './PostView.js'; function initApp() { LoginView.init(); HomeView.init(); PostView.init(); } initApp(); | cs |
위 코드는 해당 서비스가 싱글 페이지 애플리케이션이라고 가정하고 작성한 코드입니다. 사용자의 로그인 화면, 로그인 후 진입하는 메인 화면, 그리고 게시글을 작성하는 화면 등 웹 서비스에 필요한 화면들이 모두 index.js 파일에서 불려져 사용되고 있기 때문에 웹팩을 실행하면 해당 파일들의 내용까지 해석하여 파일을 빌드해 줄 것입니다.
위와 같이 모듈 간의 의존 관계가 생기는 구조를 디펜던시 그래프라고 합니다.
[ Entry 유형 ]
앞에서 살펴본 것처럼 엔트리 포인트는 1개가 될 수도 있지만 아래와 같이 여러 개가 될 수도 있습니다.
1 2 3 4 | entry: { login: './src/LoginView.js', main: './src/MainView.js' } | cs |
위와 같이 엔트리 포인트를 분리하는 경우는 싱글 페이지 애플리케이션이 아닌 특정 페이지로 진입했을 때 서버에서 해당 정보를 내려주는 형태의 멀티 페이지 애플리케이션에 적합합니다.
[ Output ]
output 속성은 웹팩을 돌리고 난 결과물의 파일 경로를 의미합니다.
1 2 3 4 5 6 | // webpack.config.js module.exports = { output: { filename: 'bundle.js' } } | cs |
앞에서 배운 entry 속성과는 다르게 객체 형태로 옵션들을 추가해야 합니다.
[ Output 속성 옵션 형태 ]
최소한 filename은 지정해줘야 하며 일반적으로 아래와 같이 path 속성을 함께 정의합니다.
1 2 3 4 5 6 7 8 9 | // webpack.config.js var path = require('path'); module.exports = { output: { filename: 'bundle.js', path: path.resolve(__dirname, './dist') } } | cs |
여기서 filename 속성은 웹팩으로 빌드한 파일의 이름을 의미하고, path 속성은 해당 파일의 경로를 의미합니다.
그리고 path 속성에서 사용된 path.resolve() 코드는 인자로 넘어온 경로들을 조합하여 유효한 파일 경로를 만들어주는 Node.js API 입니다.
이 API가 하는 역할을 좀 더 이해하기 쉽게 표현하면 아래와 같습니다.
1 | output: './dist/bundle.js' | cs |
[ Output 파일 이름 옵션 ]
앞에서 살펴본 filename 속성에 여러 가지 옵션을 넣을 수 있습니다.
1. 결과 파일 이름에 entry 속성을 포함하는 옵션
1 2 3 4 5 | module.exports = { output: { filename: '[name].bundle.js' } }; | cs |
2. 결과 파일 이름에 웹팩 내부적으로 사용하는 모듈 ID를 포함하는 옵션
1 2 3 4 5 | module.exports = { output: { filename: '[id].bundle.js' } }; | cs |
3. 매 빌드시 마다 고유 해시 값을 붙이는 옵션
1 2 3 4 5 | module.exports = { output: { filename: '[name].[hash].bundle.js' } }; | cs |
4. 웹팩의 각 모듈 내용을 기준으로 생성된 해시 값을 붙이는 옵션
1 2 3 4 5 | module.exports = { output: { filename: '[chunkhash].bundle.js' } }; | cs |
이렇게 생성된 결과 파일의 이름에는 각각 엔트리 이름, 모듈 아이디, 해시 값 등이 포함됩니다.
[ Loader가 필요한 이유 ]
웹팩으로 애플리케이션을 빌드할 때 만약 아래와 같은 코드가 있다고 해보겠습니다.
1 2 3 4 5 | // app.js import './common.css'; console.log('css loaded'); | cs |
1 2 3 4 | /* common.css */ p { color: blue; } | cs |
1 2 3 4 5 6 7 | // webpack.config.js module.exports = { entry: './app.js', output: { filename: 'bundle.js' } } | cs |
위 파일을 웹팩으로 빌드하게 되면 아래와 같은 에러가 발생합니다.
위 에러 메시지의 의미는 app.js 파일에서 임포트한 common.css 파일을 해석하기 위해 적절한 로더를 추가해 달라는 것입니다.
[ CSS Loader 적용하기 ]
이 때 해당 폴더에 아래의 NPM 명령어로 CSS 로더를 설치하고 웹팩 설정 파일 설정을 바꿔주면 에러를 해결할 수 있습니다.
1 | npm i css-loader -D | cs |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 | // webpack.config.js module.exports = { entry: './app.js', output: { filename: 'bundle.js' }, // 아래부터 추가된 부분입니다. module: { rules: [ { test: /\.css$/, use: ['css-loader'] } ] } } | cs |
위의 module 쪽 코드를 보면 rules 배열에 객체 한 쌍을 추가했습니다. 그리고 그 객체에는 2개의 속성이 들어가 있는데 각각 아래와 같은 역할을 합니다.
- test: 로더를 적용할 파일 유형 (일반적으로 정규 표현식을 사용합니다.)
- use: 해당 파일에 적용할 로더의 이름
정리하자면 위 코드는 해당 프로젝트의 모든 CSS 파일에 대해서 CSS 로더를 적용하겠다는 의미입니다.
적용 후 빌드하면 정상적으로 실행되는 것을 알 수 있습니다.
[ 자주 사용되는 로더의 종류 ]
앞에서 살펴본 CSS 로더 이외에도 실제 서비스를 만들 때 자주 사용되는 로더의 종류는 다음과 같습니다.
- 로더를 여러 개 사용하는 경우에는 아래와 같이 rules 배열에 로더 옵션을 추가해주면 됩니다.
1 2 3 4 5 6 7 8 9 | module.exports = { module: { rules: [ { test: /\.css$/, use: 'css-loader' }, { test: /\.ts$/, use: 'ts-loader' }, // ... ] } } | cs |
[ 📌 로더 적용 순서 ]
특정 파일에 대해 여러 개의 로더를 사용하는 경우 로더가 적용되는 순서에 주의해야 합니다. 로더는 기본적으로 오른쪽에서 왼쪽 순으로 적용됩니다.
CSS의 확장 문법인 SCSS 파일에 로더를 적용하는 예시를 보겠습니다.
1 2 3 4 5 6 7 8 | module: { rules: [ { test: /\.scss$/, use: ['css-loader', 'sass-loader'] } ] } | cs |
위 코드는 scss 파일에 대해 먼저 Sass 로더로 전처리(scss 파일을 css 파일로 변환)를 한 다음 웹팩에서 CSS 파일을 인식할 수 있게 CSS 로더를 적용하는 코드입니다.
만약 웹팩으로 빌드한 자원으로 실행했을 때 해당 CSS 파일이 웹 애플리케이션에 인라인 스타일 태그로 추가되는 것을 원한다면 아래와 같이 style 로더도 추가할 수 있습니다.
1 2 3 4 | { test: /\.scss$/, use: ['style-loader', 'css-loader', 'sass-loader'] } | cs |
그리고, 위와 같이 배열로 입력하는 대신 아래와 같이 옵션을 포함한 형태로도 입력할 수 있습니다.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | module: { rules: [ { test: /\.css$/, use: [ { loader: 'style-loader' }, { loader: 'css-loader', options: { modules: true } }, { loader: 'sass-loader' } ] } ] } | cs |
[ Plugin ]
플러그인(plugin)은 웹팩의 기본적인 동작에 추가적인 기능을 제공하는 속성입니다. 로더랑 비교하면 로더는 파일을 해석하고 변환하는 과정에 관여하는 반면, 플러그인은 해당 결과물의 형태를 바꾸는 역할을 한다고 보면 됩니다.
플러그인은 아래와 같이 선언합니다.
1 2 3 4 | // webpack.config.js module.exports = { plugins: [] } | cs |
플러그인의 배열에는 생성자 함수로 생성한 객체 인스턴스만 추가될 수 있습니다. 예를 들어보겠습니다.
1 2 3 4 5 6 7 8 9 10 11 | // webpack.config.js var webpack = require('webpack'); var HtmlWebpackPlugin = require('html-webpack-plugin'); module.exports = { plugins: [ new HtmlWebpackPlugin(), new webpack.ProgressPlugin() ] } | cs |
위의 두 플러그인은 각각 아래와 같은 역할을 합니다.
- HtmlWebpackPlugin : 웹팩으로 빌드한 결과물로 HTML 파일을 생성해주는 플러그인
- ProgressPlugin : 웹팩의 빌드 진행율을 표시해주는 플러그인
[ 자주 사용하는 플러그인 ]
[ 요약 ]
위에서 살펴본 웹팩 4가지 주요 속성을 도식으로 나타내보면 다음과 같습니다.
1. Entry 속성은 웹팩을 실행할 대상 파일이자 진입점을 말한다.
2. Output 속성은 웹팩의 결과물에 대한 정보를 입력하는 속성이며, 일반적으로 filename과 path를 정의한다.
3. Loader 속성은 CSS, 이미지와 같은 비 자바스크립트 파일을 웹팩이 인식할 수 있게 추가하는 속성이며, 로더는 오른쪽에서 왼쪽 순으로 적용한다.
4. Plugin 속성은 웹팩으로 변환한 파일에 추가적인 기능을 더하고 싶을 때 사용하는 속성이며, 웹팩 변환 과정 전반에 대한 제어권을 갖고 있다.
'이모저모 > Bundler' 카테고리의 다른 글
[Webpack] 소스 맵(Source Map)이란? (0) | 2023.05.20 |
---|---|
[Webpack] Webpack Dev Server란? (0) | 2023.05.20 |
[Webpack] Webpack이란? (0) | 2023.05.17 |
[Webpack] dependencies와 devDependencies의 차이 (0) | 2023.05.17 |
[Webpack] NPM 설치 명령어 (0) | 2023.05.17 |