일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- 파스에러
- javascript
- Android
- js
- 크라코
- 타입스크립트
- 유니온타입
- 리액트쿼리
- react-native-vision-camera
- sort( )
- react-native
- React
- reactnative
- 리액트네이티브
- Typescript
- react-native-image-picker
- react-hook-form
- 프로그래머스
- 리액트
- 모던자바스크립트
- 제네릭타입
- Flipper
- 자바스크립트
- 배열
- craco
- react-native-camera-roll
- 자료구조와알고리즘
- 코드숨
- ios
- slice
Archives
- Today
- Total
KassyLog
craco란? 본문
@craco/craco
Create React App Configuration Override, an easy and comprehensible configuration layer for create-react-app.. Latest version: 7.0.0, last published: a month ago. Start using @craco/craco in your project by running `npm i @craco/craco`. There are 370 other
www.npmjs.com
상대 경로 지옥에서 벗어나기 위한 craco
../을 무한 반복 하여 찾는 불편함을 해소할 craco
Craco는 Create-React-App Configuration Override의 약어로, 말 그대로 CRA에 config 설정을 덮어쓰기 위한 패키지이다.
1. 설치
npm i @craco/craco
2.package.json scripts 수정
"scripts": {
"start": "craco start",
"build": "craco build",
"test": "craco test",
"eject": "craco eject"
}
2-1. rm -rf node_modules package-lock.json 으로node_modules과 package-lock.json을 삭제후 npm install을 통해 재설치를 한다.
3. 프로젝트 root 경로에 craco.config.js(설정파일) 만들기 (아래의 폴더명은 예시이다.)
//craco.config.js
/* eslint-disable */
const path = require("path");
module.exports = {
/*
eslint: {
enable: false
},
*/
webpack: {
baseUrl: ".",
alias: {
"#assets": path.resolve(__dirname, "public/assets"),
//----------------------------------------
"#components": path.resolve(__dirname, "src/components"),
"#helpers": path.resolve(__dirname, "src/helpers"),
"#i18n": path.resolve(__dirname, "src/i18n"),
"#navs": path.resolve(__dirname, "src/navigations"),
"#pages": path.resolve(__dirname, "src/pages"),
"#stores": path.resolve(__dirname, "src/stores"),
"#styles": path.resolve(__dirname, "src/styles"),
"#utils": path.resolve(__dirname, "src/utils"),
},
},
jest: {
configure: {
moduleNameMapper: {
"^\\#assets/(.*)$": "<rootDir>/public/assets/$1",
//----------------------------------------------------------
"^\\#components/(.*)$": "<rootDir>/src/components/$1",
"^\\#helpers/(.*)$": "<rootDir>/src/helpers/$1",
"^\\#i18n/(.*)$": "<rootDir>/src/i18n/$1",
"^\\#navs/(.*)$": "<rootDir>/src/navigations/$1",
"^\\#pages/(.*)$": "<rootDir>/src/pages/$1",
"^\\#stores/(.*)$": "<rootDir>/src/stores/$1",
"^\\#styles/(.*)$": "<rootDir>/src/styles/$1",
"^\\#utils/(.*)$": "<rootDir>/src/utils/$1",
},
},
},
};
결과
import DashboardSpinner from "../../../../pages/home";
import DashboardSpinner from "../../../../components/Header";
🔽
import Home from '#pages/home';
import Header from "#components/Header";
'react' 카테고리의 다른 글
리코일 (0) | 2023.03.27 |
---|---|
리액트 쿼리 (0) | 2023.03.27 |
emotion과 styled-components (0) | 2023.03.26 |
Refresh Token (0) | 2022.12.15 |
사진 다운로드 기능 (0) | 2022.12.13 |