일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- git 개행문자
- 응답코드
- IP주소
- 개행문자
- 퀵정렬
- 가장큰수
- JadenCase
- k번째수
- CRLF
- REST API
- 참조타입
- input 안보임
- eslint-prettier
- CRA
- password 안보임
- git
- eslint
- HTTPS
- 프로그래머스
- expected linebreaks to be 'crlf' but found 'lf' linebreak-style
- lazy-load
- LF
- input type password
- git autocrlf
- expected linebreaks to be 'lf' but found 'crlf' linebreak-style
- git 명령어
- react
- 원시값
- vscode
- prettier
- Today
- Total
우파루파의 개발 기록
[React.js] ESLint와 Prettier를 이용한 React 환경 설정 (VSCode) 본문
[React.js] ESLint와 Prettier를 이용한 React 환경 설정 (VSCode)
upa-r-upa 2021. 6. 19. 23:13
들어가며
프로젝트를 진행할 때 꼭 필요한 Lint 설정을 진행합니다. Lint란 무엇이고, 왜 필요한 지에 대해서 학습합니다.
최종적으로Prettier
, ESLint
를 사용하여 VSCode에서 저장 할 때마다 자동으로 원하는 스타일로 Auto formating 해주는 설정 방법에 대해서 알아봅니다.
본 글에서는 React + Typescript 설정을 기준으로 하며, JS 설정을 하고 계신다면 typescript 관련된 내용을 제외하고 적용하시면 됩니다.
Lint가 필요한 이유
설명에 들어가기 앞서, Lint/Linter의 개념부터 알아봅니다.
Lint, Linter란
소스코드를 분석하여 문법적인 오류나 스타일적인 오류, 적절하지 않은 구조 등에 표시를 달아주는 행위이고, Linter란 Lint의 동작을 도와주는 도구를 말합니다.
Formatter란
프로젝트를 진행하며 소스코드를 작성할 때, 정해진 스타일 가이드라인을 따를 수 있도록 변환해주는 도구입니다.
Linter와 Formater를 잘 설정해둔다면 소스 코드를 원하는 문법 스타일로 자동으로 변경하고, 오류를 자동으로 수정하는 등 개발에 있어 아주 유용하고 빠질 수 없는 도구 중 하나 입니다.
그래서 왜 Linter를 쓸까
프로젝트를 진행할 때 작성해야 하는 코드는 작은 프로젝트가 아니라면 그 양이 어마어마합니다. 그런데 코드에 대한 상세한 규약을 온전히 사람이 관리해야 한다면 어떨까요?
소스 코드는 세미콜론을 꼭 붙이고, 변수 선언 이후에는 한 줄 띄어쓰고, 화살표 함수 말고 기본 function을 쓰고...
이러한 규약이 적다면 그나마 기억하기 쉽겠지만, 규칙이 세부화 되거나 혼자 개발하는 것이 아닌 다른 사람과의 협업을 해야하는 상황이라면 규약을 지키기가 아주 난감하게 됩니다.
이러한 애로사항을 해결하는 방법이 바로 Linter
입니다.
특히 자바스크립트(이하 JS)의 경우는 컴파일 과정이 없는 인터프리터 언어이기 때문에, 코드가 실행되는 런타임 환경에서 에러가 발생할 수 있게 됩니다.
이런 불상사를 방지하기 위해 런타임 이전에 코드의 오류를 찾을 수 있도록 Linter를 사용하는 것이 좋습니다.
JS의 대표적인 린터의 종류
이전엔 JSLint
, JSHint
등의 린트들이 많이 쓰였으나 최근은 거의 ESLint
를 사용하는 추세입니다.
별개로 Typescript만을 위한 lint인 TSLint
도 있으나, 현재는 ESLint
와 통합으로 Deprecated 되었습니다.
Prettier, ESLint 설정하기
ESLint 설치
$ npm install eslint --save-dev
Prettier 설치
$ npm install prettier --save-dev --save-exact
Prettier, ESLint 관련 설정 모듈들 설치
$ npm install eslint-plugin-prettier eslint-config-prettier --save-dev
- eslint-plugin-prettier
- ESLint와 Prettier이 충돌할 수 있는 설정들을 비활성화 시켜줍니다.
- eslint-config-prettier
- ESLint의 포맷 기능이 아닌 Prettier의 포맷 기능을 사용하게 만들어 줍니다.
Extension 설치하기 (Only used VSCode)
VSCode extension에서 Prettier ESLint
를 설치해줍니다.
ESLint 설정 파일 작성하기
프로젝트 최상단 Root 경로에 .eslintrc.js
파일을 생성 해줍니다.
module.exports = {
root: true,
env: {
browser: true,
es6: true,
},
extends: [
"plugin:@typescript-eslint/recommended",
// typescript 표준 규칙 모음
"plugin:import/errors",
"plugin:import/warnings",
"plugin:import/typescript",
// import 관련 규칙 모음
"plugin:prettier/recommended",
"prettier/@typescript-eslint",
"prettier/react",
// prettier 관련 규칙 모음
],
parserOptions: {
ecmaVersion: 2018,
project: ["./tsconfig.json"],
// tsconfig 파일의 경로를 참조 해줍니다.
// 기준은 root 입니다.
},
rules: {
// 추가하고 싶은 rule을 더 추가해줍니다.
}
};
지금은 간소화된 파일이지만, https://eslint.org/docs/rules/ 에서 원하는 설정을 추가해가며 사용하면 됩니다.
Prettier 설정 파일 작성하기
프로젝트 최상단 Root 경로에 .prettierrc.js
파일을 생성 해줍니다.
module.exports = {
endOfLine: "lf",
tabWidth: 4,
semi: true,
singleQuote: false,
trailingComma: "all",
printWidth: 120,
};
지금은 간소화된 파일이지만, 에서 원하는 설정을 추가해가며 사용하면 됩니다.
VSCode 사용자 설정하기 (Only used VSCode)
VSCode의 settings.json
파일을 수정해줍니다.
{
"editor.defaultFormatter": "esbenp.prettier-vscode",
"[typescriptreact]": {
"editor.defaultFormatter": "esbenp.prettier-vscode"
},
"[typescript]": {
"editor.defaultFormatter": "esbenp.prettier-vscode"
},
"editor.formatOnSave": true
}
이렇게까지 설정하고 나면 저장할 때마다 코드가 자동으로 포매팅 되는 것을 확인할 수 있습니다.
마치며
이번 개발을 할 때 필수적인 린트에 대해서 알아보았습니다.
모쪼록 도움이 되는 내용이었으면 좋겠습니다. 감사합니다.
참고 문서
'development > React' 카테고리의 다른 글
[React.js] 요즘 잘 사용하고 있는 VSCode에서의 Typescript ESLint/Prettier 환경 함께 설정하기 (0) | 2022.10.08 |
---|---|
[Gatsby.js] Gatsby+Typescript에서 styled-component 본격 설정하기 (0) | 2022.09.30 |
[React.js] Styled Components 간단 정리 [Basic] (0) | 2021.06.24 |
[React.js] Shallow compare와 Class component에서의 최적화 (22.04.13. 내용 수정 및 추가) (0) | 2021.06.17 |
CRA를 이용해서 Typescript 프로젝트 만들기 (+ 유사 절대 경로 설정하기(vsCode)) (0) | 2020.05.21 |