Skip to content

우리팀 컨벤션

Ji Yoon Choi edited this page Nov 15, 2022 · 10 revisions

Git 브랜치 전략 - Git flow + PR

이유

  • 브랜치의 구분을 명확히 하기 위해서

종류

  • main
    • 개발이 완료된 dev 브랜치를 merge 하여 배포 가능한 상태만을 관리하는 브랜치
  • dev
    • 개발이 진행되는 브랜치, 이 브랜치를 기반으로 feat, refactor 등으로 파생됩니다.
    • feat/[fe or be]-[기능_명]
      • 새로운 기능을 추가하고자 할 때, 사용하는 브랜치입니다.
    • refactor/[fe or be]-[기능_명]
      • 리팩토링이 이루어지는 브랜치입니다.
    • fix/[fe or be]-[기능_명]
      • 버그를 수정하기 위한 브랜치입니다.
    • design/[fe or be]-[기능_명]
      • 디자인 관련 작업을 하는 브랜치입니다.
    • structure/[fe or be]-[기능_명]
      • 공통 구조 작업을 하는 브랜치입니다.

코딩 컨벤션

대소문자 컨벤션

  • camelCase
    • 일반적인 함수(hook 포함)
    • 일반적인 변수
  • PascalCase
    • 컴포넌트 관련한 파일, 폴더, 명
    • class 명
  • snake_case
    • DB
    • 상수(영문 대문자 사용)
  • kebab-case
    • html 요소

변수 네이밍

  • 배열의 이름은 복수형으로 만듭니다.
    // 예시
    chatArray // X
    chatList // X
    chats // O
    
  • 반환 값이 boolean 형인 함수나 변수는 is 또는 has 로 시작합니다.
  • 매직넘버 사용 금지(변수나 상수로 분리)

순서 컨벤션

  • constlet 보다 상단에 작성합니다.
  • 변수는 사용 시점에 선언 및 할당합니다.
  • 선언과 할당을 동시에 하는 변수를 선언만 하는 변수보다 먼저 선언합니다.
  • import 순서
    • 외부모듈 -> 내부모듈 -> style -> assets 순서로 작성합니다.
    // 예시
    import React from 'react'
    
    import Main from './Main'
    
    import colors from './style'
    
    import icons from './assets'
    
    • 선언 그룹 사이에 공백을 둡니다.

.prettierrc & eslint

  • 지윤님이 쓰시던 규칙 사용

프론트엔드 함수 형식

  • 선언형 (function foo() {})
    • Hook 등의 로직
    • 유틸 함수 등, 통상적인 함수들
  • 화살표 함수 (foo = () ⇒ {})
    • 컴포넌트
    • 콜백 함수
  • 클래스 (class Foo {})
    • 생성자로 인스턴스를 만들어야 할 때 (this가 필요할 때)

프론트엔드 함수 이름

  • 핸들러 함수
    • handle + 동사 + 목적어
    • 예시: handleClickButton, handleSubmitForm

프론트엔드 함수 선언 위치

  • 컴포넌트 안에서 사용되는 핸들러 함수의 경우, 컴포넌트 안에 선언하되 useCallback으로 감싸줄 것 (재선언 방지)
  • setStateAction을 호출하는 핸들러 외의, 기타 유틸 함수들은 컴포넌트 밖에 선언할 것

Router 컨벤션

<Route path='/auth'>
   <Route path='/github' />
   <Route path='login' />
</Route>
  • 부모-자식 라우터가 생길 것을 고려하여 컴포넌트 형식으로 작성
    • createBrowserRouter을 사용하면 부모-자식간 상관관계가 직관적이지 않을 우려 있음?

커밋 컨벤션

  • 제목은 확실히 적어줍니다.
  • 본문은 optional.
# <타입>: <제목> (#1)

##### 제목은 최대 50 글자까지만 입력 ############## -> |


# 본문은 위에 작성
######## 본문은 한 줄에 최대 72 글자까지만 입력 ########################### -> |
# --- COMMIT END ---
# <타입> 리스트
#   feat      : 기능 (새로운 기능)
#   fix       : 버그 (버그 수정)
#   refactor  : 리팩토링
#   style     : 스타일 (코드 형식, 세미콜론 추가: 비즈니스 로직에 변경 없음)
#   docs      : 문서 (문서 추가, 수정, 삭제)
#   test      : 테스트 (테스트 코드 추가, 수정, 삭제: 비즈니스 로직에 변경 없음)
#   chore     : 기타 변경사항 (빌드 스크립트 수정 등)
#   structure : 공통 구조 작업
# ------------------
#     타입은 영어로 작성하고 제목과 본문은 한글로 작성한다.
#     제목 끝에 마침표(.) 금지
#     제목과 본문을 한 줄 띄워 분리하기
#     본문은 "어떻게" 보다 "무엇을", "왜"를 설명한다.
#     본문에 여러줄의 메시지를 작성할 땐 "-"로 구분
#     관련된 이슈번호는 제목 맨 뒤에 추가한다. ex. (#1)
# ------------------

폴더 구조

- client
|- public
   |- index.html
|- src
   |- assets
      |- images # png jpg
      |- svgs # svg export
   |- common # 공용 컴포넌트 (2개 이상의 페이지에서 같이 쓰임)
      |- hooks
      |- utils
      |- components
   |- pages
      |- TestPage1
         |- TestComponent1 # TestPage1 에서만 사용되는 컴포넌트
         |- TestComponent2
      |- TestPage2
   |- store # 전역 상태관리 상태값들 (redux dispatch 또는 recoil atom)
      |- testState1
         |- atoms.ts
         |- selectors.ts
   |- services # axios 또는 fetch 함수들
      |- fetchTest.ts
   |- styles
      |- colors.ts # 색상값
      |- sizes.ts # border size, box size 등 사이즈 공용값
      |- reset.css # 기본 스타일 리셋
   |- types # 타입 값들
      |- test.d.ts
   |- api.ts # axios 를 쓰게 된다면 설정값
   |- App.tsx # 일단은 라우터도 여기로
   |- index.tsx # React가 읽어들이는 엔드포인트
|- prettierrc.json
|- eslintrc.json
|- tsconfig.json
|- package.json
|- .env

- server
|- app.ts
|- 도메인 별로 폴더
|- user // 예시
   |- userController
   |- userService
   |- userRepository
|- utils
   |- ...

얼리버드

프로젝트

개발일지

스프린트 계획

멘토링

데일리 스크럼

데일리 개인 회고

위클리 그룹 회고

스터디

Clone this wiki locally