Po_tta_tt0
콩심콩 팥심팥 🌱
Po_tta_tt0
전체 방문자
오늘
어제
  • 분류 전체보기 (266)
    • 🐛 회고 (14)
    • 💭 생각 (2)
    • 🤸‍♀️ 내 프로젝트 (16)
      • FISH-NEWS (8)
      • MBTI 과몰입 테스트 (2)
      • twitter clonecoding with TS (4)
      • pilzagenda (2)
    • 👨‍👩‍👧‍👦 팀 프로젝트 (2)
      • 피우다 프로젝트 (0)
      • SEMO(세상의 모든 모임) (1)
      • 마음을 전하는 텃밭 (1)
      • Stackticon (0)
    • 👨‍💻 CS지식 (11)
    • ✍ 공부 (94)
      • JavaScript (21)
      • TypeScript (39)
      • Html (0)
      • CSS (2)
      • React (18)
      • NextJS (7)
      • Vue (1)
      • Python (1)
      • Django (0)
      • 개발환경 & 그 외 (2)
    • 🏄‍♀️ 코딩테스트 (99)
      • 🐍 Python (99)
    • 🐙 Git & GitHub (3)
    • 📑 오류기록 (8)
    • 📚 우리를 위한 기록 (9)
    • 수업 (3)
    • 강의 등 (2)
    • 👩‍🎓 SSAFY (0)
    • 👋 우테코 (0)

블로그 메뉴

  • 홈
  • 태그

공지사항

인기 글

태그

  • 문자열
  • 시뮬레이션
  • 파이썬 감시 피하기
  • React
  • 파이썬 다익스트라
  • js
  • 플로이드 워셜
  • react-router-dom
  • 이분탐색
  • 백준
  • DP
  • BFS + DP
  • 백준 숨바꼭질
  • 구현
  • 자바스크립트
  • 파이썬
  • 백준 파이썬
  • dfs
  • bfs
  • Next.js

최근 댓글

최근 글

티스토리

hELLO · Designed By 정상우.
Po_tta_tt0

콩심콩 팥심팥 🌱

✍ 공부/React

React 프로젝트 구조 잡기

2022. 6. 8. 14:49
반응형

 

 

 

작성 이유

  1. 구조를 하나도 생각하지 않고 만든 프로젝트 리팩토링하면서 너무 고통받아서
  2. 팀 프로젝트를 진행할 때 체계적인 구조를 잡고 진행하는 것이 좋을 것 같아서

 

0. React 공식문서

React는 파일을 어떤 식으로 폴더에 분류할 것인지에 대해서 제시하고 있지는 않습니다. 그러나 React 생태계 내에서 고려할만한 몇 가지 인기 있는 일반적인 접근법들이 있습니다.

 

 

✍ 파일의 기능이나 라우트에 의한 분류

 

일반적인 방법 중 하나.
CSS, JS, 테스트 파일을 기능이나 라우트로 분류된 폴더에 같이 두는 방법

common/
  Avatar.js
  Avatar.css
  APIUtils.js
  APIUtils.test.js
feed/
  index.js
  Feed.js
  Feed.css
  FeedStory.js
  FeedStory.test.js
  FeedAPI.js
profile/
  index.js
  Profile.js
  ProfileHeader.js
  ProfileHeader.css
  ProfileAPI.js

 

 

✍ 파일 유형에 의한 분류

 

비슷한 파일끼리 묶어주기

api/
  APIUtils.js
  APIUtils.test.js
  ProfileAPI.js
  UserAPI.js
components/
  Avatar.js
  Avatar.css
  Feed.js
  Feed.css
  FeedStory.js
  FeedStory.test.js
  Profile.js
  ProfileHeader.js
  ProfileHeader.css

 

 

✍ 내 방법

현재 리팩토링중인 pilzAgendq를 기준으로 예를 들면,
component 폴더 안에 컴포넌트 관련된 내용.


이를 또 두개로 쪼개서 ui(button이나 form), 일반적 컴포넌트로 나누고

service 폴더 안에서 firebase와 소통하거나 유저 정보를 불러오는 로직을 각각 처리한다

 

routes 폴더 안에서는 경로에 따른 큰 박스들을 넣어둔다

 

 

반응형

'✍ 공부 > React' 카테고리의 다른 글

함수형 컴포넌트로 ref 보내기 | forwardRef에 대해 알아보자  (0) 2022.06.12
[ 🐱‍💻 강의 노트 ] React 완벽 가이드 강의 정리 섹션 10 | 리듀서(Reducer)을 사용하여 부작용 처리 & 컨텍스트 API(Context) 사용하기  (0) 2022.06.12
[ 🐱‍💻 강의 노트 ] React 완벽 가이드 강의 정리 섹션 27 | React + TypeScript 사용하기  (0) 2022.06.01
[ 🐱‍💻 강의 노트 ] React 완벽 가이드 강의 정리 섹션 29 | 리엑트 요약 및 핵심 기능  (0) 2022.05.31
[ 🐱‍💻 강의 노트 ] React 완벽 가이드 강의 정리  (0) 2022.05.26
    '✍ 공부/React' 카테고리의 다른 글
    • 함수형 컴포넌트로 ref 보내기 | forwardRef에 대해 알아보자
    • [ 🐱‍💻 강의 노트 ] React 완벽 가이드 강의 정리 섹션 10 | 리듀서(Reducer)을 사용하여 부작용 처리 & 컨텍스트 API(Context) 사용하기
    • [ 🐱‍💻 강의 노트 ] React 완벽 가이드 강의 정리 섹션 27 | React + TypeScript 사용하기
    • [ 🐱‍💻 강의 노트 ] React 완벽 가이드 강의 정리 섹션 29 | 리엑트 요약 및 핵심 기능
    Po_tta_tt0
    Po_tta_tt0
    감자의 코딩하는 블로그 콩심은데 콩나고 팥심은데 팥난다

    티스토리툴바