Skip to content

Latest commit

 

History

History
123 lines (98 loc) · 4.72 KB

README.md

File metadata and controls

123 lines (98 loc) · 4.72 KB

바로가기

  • 권장버전
  • 설치방법
  • 실행방법
  • 빌드방법
  • [프로젝트 구조에 대해 설명해주세요.](#프로젝트 구조에 대해 설명해주세요.)
  • [새로운 화면은 어떻게 만들면 되나요?](#새로운 화면은 어떻게 만들면 되나요?)
  • [API 연동은 어떻게 하면 될까요?](#API 연동은 어떻게 하면 될까요?)
  • [3rd party API 연동은 어떻게 하면 될까요?](#3rd party API 연동은 어떻게 하면 될까요?)

Quick start

권장버전

npm -v
# 8.19.2

node -v
# v18.12.1

설치방법

npm install -g eslint prettier
# lint 와 prettier 가 작동 할 수 있도록 global 로 설치해주세요.

npm install

실행방법

npm run start # 로컬에서 실행

빌드방법

npm run build-dev # dev 환경용 build 파일 생성

npm run build-stage # stage 환경용 build 파일 생성

npm run build-prod # prod 환경용 build 파일 생성

프로젝트 구조에 대해 설명해주세요.

> .husky                    # git hook 을 실행시켜주는 폴더 (수정X)
> public
    > favicon.ico           # 브라우저 탭에 나오는 아이콘 파일
    > index.html            # React 소스를 랜더링하기 위한 Root DOM
    > manifest.json         # index.html 에 쓰일 값들 정의
> src
    > apis
        > core
            > index.ts      # axios 사용시 request, response 설정 파일
        > businessModel.ts  # 리소스 단위로 파일을 만들어서 API 를 호출하도록 관리
    > assets                # jpg, png 등 이미지 에셋 폴더
        > ...
    > components            # 반복적으로 쓰이는 컴포넌트 폴더
        > ...
    > config                # 프로젝트 내에 사용되는 설정 파일 폴더
        > constant.ts       # 상수 파일
    > layout
        ...                 # 반복적으로 쓰이는 레이아웃 폴더
    > models                # API Request, Response 에 쓰이는 모델 클래스 폴더
        ...
    > pages                 # 화면별 폴더를 만들고 index.ts, styles.tsx 로 html, css 파일 분리
        > ...
    > scss                # CSS 파일들
        > ...
    > utils                 # 공통적으로 쓰이는 함수 모음 유틸 폴더
        > ...
    _nav.tsx                # 좌측 네비게이션 항목 정의
    index.tsx               # 프로젝트 Root 파일
    routes.ts               # 프로젝트 Routing 정의 파일
    store.ts                # Redux 파일
.browserslistrc             # 브라우저 호환성을 위한 browserslist 설정 파일
.editorconfig               # 편집툴 공통 설정 파일
.env.development            # development 환경에서 사용 할 환경변수 정의 파일
.env.development.local      # local ""
.env.production             # production ""
.env.staging                # staging ""
.eslintignore
.eslintrc.js                # 코드 퀄리티를 통일하기 위한 lint 설정 파일
.gitattributes
.gitignore
.prettierignore
.prettierrc.js              # 코드 컨벤션을 통일하기 위한 prettier 설정 파일
package.json                # node 모듈을 설치하고 실행, 빌드하는 명령어와 설정 모음 파일
README.md
svg.d.ts                    # svg 파일을 ts 에서 불러올 수 있도록 하는 설정 파일
tsconfig.json               # typescript 를 javascript 로 변환하는 설정 파일

새로운 화면은 어떻게 만들면 되나요?

  1. src/pages 내에 화면별 폴더를 만들어주세요.
  2. 폴더내에 index.tsx 와 styles.tsx 를 만들어주세요.
  3. styles.tsx 에는 styled-components 컴포넌트들을 정의해주세요.
  4. index.tsx 에서 styles.tsx 컴포넌트를 불러와서 랜더링해주세요.

API 연동은 어떻게 하면 될까요?

  1. src/apis/리소스별파일.ts 파일을 만들어주세요.

  2. API 호출시 사용되는 Response Model Class 를 만들어주세요.

  • (Request 파라미터가 많거나 리소스단위를 넘겨야 할때는 Request Model Class 를 만들어서 활용해주세요.)
  1. 위와 같이 API 호출 소스를 작성한 후 src/pages/폴더/index.tsx 파일에서 API 를 호출해주세요.

3rd party API 연동은 어떻게 하면 될까요?

새로운 npm 라이브러리를 사용해야 한다면 라이센스를 체크해야해요.

라이브러리마다 상업적으로 사용 가능/불가능한 라이센스를 가지고있기 때문에 꼭 확인해야해요.

좌측 네비게이션에 화면을 추가하려면 어떻게 해야하나요?

  1. src/_nav.tsx 에 navGroup 혹은 navItem 을 추가해줍니다.
  2. src/routes.ts 에 새로 만든 화면을 넣어줍니다