매일 해내는 개발/Develog

[Develog] Craco란? Craco 설치 방법

해야지 2023. 2. 8. 00:43
반응형

Craco란?

Create-React-App Configuration Override의 약어로, 말 그대로 CRA에 config 설정을 덮어쓰기 위한 패키지
Webpack의 번거로운 설정을 줄이기 위해 다양한 오버라이딩 패키지들이 등장했으며, 대표적으로 
Craco, react-app-rewired 등이 있다.

 

일단 craco를 이해하려면 eject를 알아야 한다.
CRA 즉 Create React App으로 프로젝트를 만들고 나면 최소한의 필요한 기능만으로 설정이 되어 있다.
이 때 package.json 파일에서 script 파일을 보면 eject 라는 명령어를 볼 수가 있다.

"scripts": {
    "start": "react-scripts start",
    "build": "react-scripts build",
    "test": "react-scripts test",
    "eject": "react-scripts eject"
}

eject는 "꺼내다"라는 뜻으로 프로젝트를 커스터마이징 하기 위해  숨겨진 모든 설정을 밖으로 추출해주는 명령어이다.
자세한 리액트 앱의 구성을 공부하고 싶다면 eject를 실행해서 보면된다. Webpack, Babel, ESLint, etc. 앱을 build하기 위한 모든 구성요소들을 한번에 볼 수 있다.

하지만 이를 실행하고 나면 모든 구성과 스크립트를 직접 유지관리해야 하므로 번거로울 수 있다.
Craco는 eject하지 않고도 프로젝트 루트에 있는 단일 구성 파일을 사용하여 ESLint, Babel, PostCSS 등의 구성을 사용자 지정 할 수 있다.


Craco 설정 방법

1. 크라코 최신 버전 설치

npm i -D @craco/craco

2. 프로젝트 루트 디렉토리에 Craco config파일 생성

  my-app
  ├── node_modules
+ ├── craco.config.js
  └── package.json

3. package.json파일 수정

"scripts": {
- "start": "react-scripts start"
+ "start": "craco start"
- "build": "react-scripts build"
+ "build": "craco build"
- "test": "react-scripts test"
+ "test": "craco test"
}

eject를 대체하는 것이니 eject는 안건드려도된다

 

추가로 타입스크립트 사용시 다음 설치를 진행한다.

npm i -D @craco/types

 

출처

 

[Craco] Craco 란?

이전에 CRA(Create-React-App)로 React 프로젝트를 생성할 땐 Webpack의 커스텀 필요성을 잘 느끼지 못했다. 하지만, 이번에 Boiler Plate를 제작하면서 추가적으로 설정할 부분들이 생겼다. (절대경로 alias 컴

abangpa1ace.tistory.com

 

[React] create-react-app eject란?

리액트를 사용하는 가장 큰 이유 중 하나는 손쉽고 빠르게 리액트 프로젝트를 구축할 수 있기 때문이다.

velog.io

 

Getting Started | CRACO

The current CRACO version requires Create React App 5 (react-scripts 5.x.x). If using an older version of CRA, use the appropriate version of CRACO.

craco.js.org

 

반응형