Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/heech1013/react-sass-boilerplate
보일러플레이트 + 세팅 튜토리얼
https://github.com/heech1013/react-sass-boilerplate
babel boilerplate react sass webpack
Last synced: 2 months ago
JSON representation
보일러플레이트 + 세팅 튜토리얼
- Host: GitHub
- URL: https://github.com/heech1013/react-sass-boilerplate
- Owner: heech1013
- Created: 2021-10-18T08:15:58.000Z (about 3 years ago)
- Default Branch: main
- Last Pushed: 2021-10-18T08:18:51.000Z (about 3 years ago)
- Last Synced: 2024-10-11T22:51:09.340Z (3 months ago)
- Topics: babel, boilerplate, react, sass, webpack
- Language: JavaScript
- Homepage:
- Size: 166 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# React + Sass/SCSS Boilerplate
- Webpack
- Babel
- React
- Sass/SCSS
- ESLint + Prettier## 튜토리얼
해당 보일러플레이트를 설정하는 과정을 따라가봅니다.
### 의존성 초기화
```bash
$ npm init -y
```- `-y`: 모든 설정을 default 값으로 설정(means "yes")
### 바벨 설정
> - 바벨은 그 자체만으로는 아무것도 하지 않는다. preset과 plugin을 통해 바벨이 무언가 동작하도록 만든다.
> - 각각의 preset과 plugin들은 npm 라이브러리를 가지고 있다.
> - preset은 plugin들의 집합(콜렉션)이다. preset은 수많은 plugin들을 일일이 추가하고 관리하는 불편함을 해결해준다.--
```bash
$ npm i -D @babel/core @babel/preset-env @babel/preset-react
```- 바벨은 개발 단계에서만 사용하기 때문에 devDependencies에 추가한다.
- `@babel/core`: babel compiler core
- `@babel/preset-env`: ES6+의 최신 문법을 별도의 변환 작업 없이도 편하게 사용할 수 있도록 해준다. (ES6+ 문법을 ES5로 컴파일해준다.)
- `@babel/preset-react`: 리액트 어플리케이션을 만들 때 필요한 plugin들의 모음(JSX 코드를 createElement 함수 코드로 변환해주는 plugin 등).--
```json
{
"presets": ["@babel/preset-env", "@babel/preset-react"]
}
```- 바벨 설정 파일 `.babelrc`에 preset을 추가
### 웹팩 설정
```bash
$ npm i -D webpack webpack-cli webpack-dev-server
```- `webpack`: 웹팩 라이브러리
- `webpack-cli`: 웹팩의 커맨드라인 인터페이스
- `webpack-dev-server`: 웹팩 빌드 결과물을 확인할 수 있는 개발 서버를 제공한다.--
```jsx
// webpack.config.js
module.exports = {
mode: "development",
entry: "./src/index.js",
output: {
filename: "bundle.[fullhash].js",
},
resolve: {
extensions: [".js", ".jsx"],
},
};
```- 웹팩 설정 파일: `webpack.config.js`
- `mode`: 모드 설정. 웹팩이 설정한 모드에 적합한 최적화를 진행한다.
(`string = 'production: 'none' | 'development' | 'production'`)
- `entry`: 어플리케이션 진입점을 설정.
- `output`: 번들된 파일을 저장할 경로 설정.
- `filename`: 번들된 파일의 이름 설정. `[fullhash]`는 웹팩에서 생성한 해시를 사용한다.
- `resolve`: 모듈을 해석하는 방식을 설정한다.
- `extensions`: 명시하는 확장자를 순서대로 해석한다. 사용자가 `import`할 때 확장자를 생략할 수 있도록 해준다. (default 설정은 jsx를 명시하지 않아 오류가 발생한다.)--
### 웹팩 loader 설정
```jsx
module: {
rules: [
{
test: '빌드할 파일 확장자 정규식'
exclude: '제외할 파일 정규식'
use: {
loader: '사용할 로더 이름'
option: '로더 옵션'
}
}
]
}
```- loader는 `module` - `rules` 키워드로 추가할 수 있다.
--
```bash
$ npm i -D babel-loader html-loader
```- `babel-loader`: 바벨을 웹팩에서 사용할 수 있도록 해준다.
- `html-loader`: 웹팩이 HTML을 읽을 수 있도록 해준다.--
```jsx
// webpack.config.js
module.exports = {
// ...
module: {
rules: [
{
test: /\.(js|jsx)$/,
exclude: /node_modules/,
use: {
loader: 'babel-loader',
},
},
{
test: /\.html$/,
use: [
{
loader: 'html-loader',
options: {
minimize: true,
},
},
],
},
],
},
// ...
```- 설치한 loader들을 위와 같이 `webpack.config.js` 파일에 추가해준다.
--
### 웹팩 plugin 설정
```bash
$ npm i -D html-webpack-plugin
```- `html-webpack-plugin`: `script` 태그를 사용하여 `body`에 모든 webpack 번들을 포함하는 HTML5 파일을 생성한다.
--
```jsx
// webpack.config.js
const HtmlWebpackPlugin = require('html-webpack-plugin');module.exports = {
// ...
plugins: [
new HtmlWebpackPlugin({
template: 'public/index.html',
})
],
// ...
```- plugin에 `new HtmlWebpackPlugin()`을 추가하는 것만으로 기본 세팅이 완료된다. (아래와 같이 번들을 포함하는 HTML 파일이 생성된다)
```jsx
webpack App
```
- 위 HTML 파일은 `HtmlWebpackPlugin`의 default HTML 파일이다. 만일 직접 생성한 HTML 파일을 템플릿으로 사용하고 싶다면, `template` 옵션을 지정한다. (`id`가 `root`인 `div`에 `App` 리액트 컴포넌트를 렌더링해야 하므로, 템플릿 옵션 설정은 필수에 가까울 것이다.)### 웹팩 개발 서버 설정
> `webpack dev server`의 결과물은 `webpack` 명령어(dist 내부에 번들 파일 생성)와는 다르게 메모리에 저장된다. 개발 서버를 종료하면 결과물도 사라진다.
--
```jsx
// package.json
// ...
"scripts": {
"start": "webpack-dev-server",
},
// ...
```- `script` - `start`에 `webpack-dev-server` 명령어 추가
--
```jsx
// webpack.config.js
const port = process.env.PORT || 3000;module.exports = {
// ...
devServer: {
host: "localhost",
port: port,
open: true,
},
};
```- `host`: 개발 서버의 url 설정
- `port`: 개발 서버의 port 설정
- `open`: 서버가 실행될 때 자동으로 브라우저를 열어줄지 여부 설정--
### 리액트 설정
```bash
$ npm i react react-dom
```--
```jsx
// src/index.js
import React from "react";
import ReactDOM from "react-dom";
import App from "./App";ReactDOM.render(, document.getElementById("root"));
// src/App.js
import React from "react";const App = () =>
Hello, Webpack!;export default App;
``````html
웹팩 with 리액트 보일러 플레이트
```
- 정상적으로 결과물이 빌드되는지 확인할 수 있도록 파일을 간단히 작성한다.
--
### ESLint & Prettier 설정
> ESLint와 Prettier 같이 사용하기
>
> - 기본적으로 ESLint는 코드 퀄리티에, Prettier는 코드 포맷팅에 특화되어 있지만 ESLint는 코드 포맷팅과 관련된 rule 또한 일부 포함한다.
> - 이로 인해 별도의 조치 없이 ESLint와 Prettier를 함께 사용하면, ESLint와 Prettier의 rule이 서로 충돌하는 상황이 발생한다.
> - 이러한 상황에 대응하기 위한 일반적인 솔루션으로 크게 3가지가 있다: `prettier-eslint`, `eslint-plugin-prettier`, `eslint-config-prettier`
>
> 1. `prettier-eslint`: prettier를 실행하고 난 후의 코드를 eslint로 fix하는 npm 라이브러리. prettier를 단독으로 실행하는 것보다 훨씬 느리다는 단점이 있다. (`prettier-eslint`의 메인테이너가 2017년에 해당 패키지를 더 이상 사용하지 않는다고 밝혔다.)
> 2. `eslint-plugin-eslint`: prettier를 eslint의 rule로써 동작하게 만든다. 속도가 느리며, 포맷팅 문제가 eslint 오류로 인식되어 오류 메시지가 지나치게 많아진다는 단점이 있다.
> 3. `eslint-config-prettier`(권장) eslint의 rule 중 prettier와 충돌할 수 있는 rule을 모두 비활성화한다. 속도가 가장 빠르고, ESLint는 코드 퀄리티만을, Prettier는 코드 포맷팅만을 담당하도록 관심사를 분리할 수 있기 때문에 권장되는 방법이다. (Kent C. Dodds도 이 방법을 사용하는 것이 낫다고 밝혔다.)—
```bash
$ npm i -D eslint prettier eslint-config-prettier
$ npx eslint --init
```- 관련 모듈을 설치한 후, eslint 프로젝트 초기 설정을 시작한다.
—
```
✔ How would you like to use ESLint? · style
✔ What type of modules does your project use? · esm
✔ Which framework does your project use? · react
✔ Does your project use TypeScript? · No / Yes
✔ Where does your code run? · browser
✔ How would you like to define a style for your project? · guide
✔ Which style guide do you want to follow? · airbnb
✔ What format do you want your config file to be in? · JavaScript
```- ESLint 설정을 위해 필요한 질문들에 원하는 대로 답변한다.
—
```
eslint-plugin-react@^7.21.5 eslint-config-airbnb@latest eslint@^5.16.0 || ^6.8.0 || ^7.2.0 eslint-plugin-import@^2.22.1 eslint-plugin-jsx-a11y@^6.4.1 eslint-plugin-react-hooks@^4 || ^3 || ^2.3.0 || ^1.7.0
✔ Would you like to install them now with npm? · No / Yes
```- 선택한 ESLint rule(airbnb)에 필요한 모듈을 자동으로 설치해준다.
—
```jsx
module.exports = {
env: {
browser: true,
es2021: true,
},
extends: ["plugin:react/recommended", "airbnb"],
parserOptions: {
ecmaFeatures: {
jsx: true,
},
ecmaVersion: 11,
sourceType: "module",
},
plugins: ["react"],
rules: {},
};
```- 위와 같은 모습으로 초기 `.eslintrc.js` 파일이 생성된다.
—
```jsx
// .eslintrc.js
{
"extends": [
// ...
"prettier"
]
}
```- `.eslintrc.js` 파일의 `extends`에 `"prettier"`를 추가해 `eslint-config-prettier` 모듈을 적용한다.
—
```jsx
// package.json
"scripts": {
// ...
"lint": "eslint \"src/**/*\" --fix",
}
```- `package.json` 파일의 `scripts`에 lint 명령어를 추가한다. 위 명령은 `src` 폴더 내의 모든 파일에 대해 lint 검사를 수행한다.
—
```json
{
"editor.formatOnSave": true,
"editor.defaultFormatter": "esbenp.prettier-vscode"
}
```- 코드를 저장할 때 자동으로 prettier 포맷팅이 적용되도록 VS CODE의 `setting.json`을 설정한다.
- ESLint rule 관련 경고줄이 보이지 않을 경우, VS CODE를 껐다 킨다.### Sass/SCSS 설정
```bash
$ npm i -D style-loader css-loader
```- `style-loader`: CSS를 `` 태그로 출력한다.
- `css-loader`: 웹팩이 CSS 파일(모듈)을 해석할 수 있도록 해준다.—
```jsx
// webpack.config.js
modules: {
rules: [
// ...
{
test: /\.css$/,
use: ["style-loader", "css-loader"],
},
// ...
```- `webpack.config.js`의 `modules` - `rules`에 해당 loader들을 적용한다.
- `App.css` 파일을 생성, `import`한 후 webpack dev server를 실행시키면 CSS가 적용된 것을 확인할 수 있다.—
```bash
$ npm i sass-loader -D
```- `sass-loader`: 웹팩이 Sass/SCSS 파일(모듈)을 해석할 수 있도록 해준다.
—
```jsx
// webpack.config.js
modules: {
rules: [
// ...
{
test: /\.scss$/,
use: ["style-loader", "css-loader", "sass-loader"],
},
// ...
```- `webpack.config.js` 파일의 `modules` - `rules`에 `"sass-loader"`를 추가한다.
- `App.scss` 파일을 생성, `import`한 후 webpack dev server를 실행시키면 SCSS가 적용된 것을 확인할 수 있다.> - sass 명령어를 사용하기 위해서는 추가로 모듈 `sass`를 설치한다. 참고로 기존에 많이 사용되던 모듈 `node-sass`는 21년 10월 기준 `deprecated`되었다. Sass 공식 문서에서 `node-sass`를 `sass`로 migrate할 것을 권장한다.
FIN.