[React] CRA Path Alias 설정하기

2023. 4. 11. 14:46·React/실험실
반응형

본인은 프로젝트를 만들 때 CRA를 사용해서 사용한다. 

그런데, 프로젝트를 진행하다보면 다른 경로의 모듈을 import할 때 상대 경로를 사용하면 길어지는 문제가 있다. 

절대 경로를 사용해서 src/ 에서부터 받아온다면 길이가 짧아진다. 

 

이것은 어찌보면 사소할 수 있는데, 개인적으로 코드에서 이런 사소한 부분을 해소하면 전체적인 코드의 

가독성이 좋게 느껴져서 신경을 쓰고 있다. 

 

다시 본론으로 넘어가서 상대 경로의 프로젝트를 절대 경로로 변경하기 위해서 craco를 사용하면 해결된다. 

craco는 cra로 만든 프로젝트의 경우 eject을 해야 설정이 변경 가능한 것을 설정을 덮어씌워서 

변경시켜준다. 

 

npm i --save @craco/craco

프로젝트를 설치해준다. 

 

그 다음에 루트에 craco.config.js를 만들고 설정을 세팅한다. 

const path = require('path');

module.exports = {
  webpack: {
    alias: {
      '@': path.resolve(__dirname, 'src/'),
      '@components': path.resolve(__dirname, 'src/components'),
      '@pages": path.resolve(__dirname, "src/pages"),
      
      // ...
    },
  },
};

앞서 말한 것처럼 alias를 위해서만 사용하는 것이 아닌 다른 설정을 위해서도 사용해도 된다. 

 

다음으로 package.json을 변경해준다. 

"scripts": {
   "start": "craco start",
   "build": "craco build"
   "test": "craco test"
}

기존 react-scripts였던 실행 코드를 craco로 변경해준 것이 끝이다. 

 

여기까지 설정하면 기본적인 alias는 해결된다.

하지만 자동 완성으로 모듈을 불러오면 여전히 상대 경로로 불러오는 문제가 있다. 

 

이것을 해결하기 위해서 루트에 jsconfig.json를 만들어서 설정을 추가해준다. 

{
  "compilerOptions": {
    "baseUrl": ".",
    "paths": {
      "@/*": ["./src/*"],
      "@components/*": ["./src/components/*"],
      "@pages/*": ["./src/pages/*"],

	  // ...
    }
  },
  "

이제 정말 끝이다. 

 

이렇게 설정하면 cra 환경에서 path alias로 절대 경로로 불러올 수 있다. 

반응형
저작자표시 비영리 변경금지 (새창열림)

'React > 실험실' 카테고리의 다른 글

[React] React18에서 추가된 Hook  (0) 2023.04.17
[React] useState vs useReducer  (0) 2023.04.16
[React] styled-components theme  (0) 2023.03.20
[React] swiper 부드럽게 흐르는 슬라이드  (0) 2023.03.15
[React] useForm  (0) 2023.03.05
'React/실험실' 카테고리의 다른 글
  • [React] React18에서 추가된 Hook
  • [React] useState vs useReducer
  • [React] styled-components theme
  • [React] swiper 부드럽게 흐르는 슬라이드
잉여개발자
잉여개발자
풀스택 개발자를 목표로 잉여롭게 개발 공부도 하면서 다양한 취미 생활도 즐기고 있는 잉여 개발자입니다.
  • 잉여개발자
    잉여로운 개발일지
    잉여개발자
    • 분류 전체보기 (789)
      • 개발정보 (36)
      • 개발환경 (7)
      • 개발생활 (19)
      • React (141)
        • 이론 (23)
        • 기능 (12)
        • 실험실 (88)
        • 버그 (6)
        • 패스트캠퍼스 (9)
        • Npm (3)
      • React Native (28)
        • 공통 (6)
        • TypeScript (3)
        • JavaScript (18)
        • 버그 (1)
      • Next.js (30)
        • 이론 (13)
        • 실험실 (13)
        • 버그 (3)
      • Web (35)
      • 알고리즘 (202)
        • 풀이 힌트 (39)
      • JavaScript (47)
      • TypeScript (29)
        • 기초 (27)
        • 실험실 (2)
      • Node.js (13)
        • 이론 (0)
        • 기능 (3)
        • 실험실 (9)
        • 버그 (1)
      • 도커 (4)
      • CCNA (22)
        • 이론 (4)
        • 문제 (18)
      • 취미생활 (167)
        • 잉여로운 칵테일 (2)
        • 잉여의 식물키우기 (130)
        • 잉여로운 여행기 (11)
        • 잉여의 제2외국어 (21)
        • 잉여로운 책장 (2)
      • Java (1)
        • Java의 정석 (1)
      • 꿀팁 공유 (3)
  • 태그

    영어회화
    바질 키우기
    CCNA
    영어독학
    typescript
    리액트
    네트워크
    리얼클래스
    네이버 부스트캠프
    next.js
    식물
    redux
    덤프
    ReactNative
    Babel
    javascript
    react
    알고리즘
    CSS
    타입스크립트
    바질
    자바스크립트
    프로그래머스
    Docker
    webpack
    다이소
    ChatGPT
    리얼학습일기
    Node.js
    타일러영어
  • hELLO· Designed By정상우.v4.10.1
잉여개발자
[React] CRA Path Alias 설정하기
상단으로

티스토리툴바