프론트엔드 프로젝트 구조에는 몇 가지 유형이 있나요?

WBOY
풀어 주다: 2024-08-08 16:03:39
원래의
896명이 탐색했습니다.

How many types of frontend project structures are there?

효율적이고 유지 관리가 쉬운 애플리케이션을 개발하려면 프런트엔드 프로젝트를 구조화하는 것이 매우 중요합니다. 좋은 구조는 코드를 이해하기 쉽게 만듭니다. 효율적으로 기능을 확장할 수 있습니다. 특히 사용할 때 Next.jsTypeScript는 개발 중입니다. 다음은 일반적으로 사용되는 프로젝트 구조입니다.

1. 기본구조

my-next-app/
├── public/              # Static files like images, fonts, etc.
├── src/                 # Source code
│   ├── components/      # Reusable components
│   ├── pages/           # Page components (Next.js routing)
│   ├── styles/          # CSS/SASS files
│   ├── hooks/           # Custom hooks
│   ├── contexts/        # Context API providers
│   ├── utils/           # Utility functions
│   ├── types/           # TypeScript types/interfaces
│   ├── services/        # API calls or services
│   ├── lib/             # Any additional libraries or helpers
│   └── config/          # Configuration files
├── .gitignore           # Git ignore file
├── next.config.js       # Next.js configuration
├── package.json         # npm/yarn package file
└── tsconfig.json        # TypeScript configuration
로그인 후 복사

2. 원자적 디자인 구조

Atomic Design은 크기와 기능에 따라 구성 요소를 분리하는 것을 강조하는 UI 디자인 개념입니다. 원자, 분자, 유기체, 템플릿, 페이지의 5가지 레벨로 나눌 수 있습니다

my-next-app/
├── public/                 # Static files
├── src/
│   ├── components/         # UI components
│   │   ├── atoms/          # Smallest elements like buttons, inputs
│   │   ├── molecules/      # Combinations of atoms (e.g., form groups)
│   │   ├── organisms/      # Complex UI components (e.g., header, footer)
│   │   ├── templates/      # Page templates with placeholders
│   │   └── pages/          # Page components
│   ├── pages/              # Next.js routing (can be left for dynamic routing)
│   ├── hooks/              # Custom hooks
│   ├── contexts/           # Context providers
│   ├── utils/              # Utility functions
│   ├── types/              # TypeScript interfaces/types
│   ├── services/           # API services
│   ├── lib/                # Additional libraries/helpers
│   └── config/             # Configurations
├── .gitignore
├── next.config.js
├── package.json
└── tsconfig.json
로그인 후 복사

3. 기능 기반 구조

기능 기반 구조는 새로운 기능을 더 쉽게 관리하고 확장할 수 있는 또 다른 방법입니다. 쉽습니다

my-next-app/
├── public/                 # Static files
├── src/
│   ├── features/           # Separate by features/modules
│   │   ├── featureA/
│   │   │   ├── components/ # Components specific to FeatureA
│   │   │   ├── pages/      # Pages related to FeatureA
│   │   │   ├── hooks/      # Hooks specific to FeatureA
│   │   │   ├── services/   # API calls related to FeatureA
│   │   │   └── utils/      # Utility functions for FeatureA
│   │   └── featureB/       # Another feature module
│   ├── shared/             # Shared resources across features
│   │   ├── components/     # Shared components
│   │   ├── hooks/          # Shared hooks
│   │   ├── contexts/       # Shared contexts
│   │   └── utils/          # Shared utilities
│   ├── styles/             # Global styles
│   └── config/             # Configuration files
├── .gitignore
├── next.config.js
├── package.json
└── tsconfig.json
로그인 후 복사

4. NX 또는 Turborepo를 사용한 Monorepo 구조

이 구조는 한 곳에서 여러 프로젝트 또는 모듈을 통해 프로젝트 관리를 제공합니다. 개발의 각 부분을 명확하게 분리해야 하는 대규모 팀이나 프로젝트에 적합합니다

my-next-monorepo/
├── apps/                   # Applications (Next.js, React, etc.)
│   ├── web/                # Next.js app
│   └── admin/              # Another Next.js app or admin panel
├── packages/               # Shared packages or libraries
│   ├── ui/                 # UI component library
│   ├── utils/              # Utility functions
│   ├── hooks/              # Custom hooks
│   └── services/           # API service packages
├── .gitignore
├── nx.json                 # NX configuration (if using NX)
├── turbo.json              # Turborepo configuration (if using Turborepo)
├── package.json
└── tsconfig.json
로그인 후 복사

5. 계층형 아키텍처 구조

계층형 아키텍처 설계로 프로젝트 기능 분리가 용이함

my-next-app/
├── public/                 # Static files
├── src/
│   ├── presentation/       # UI components, pages, and routing
│   │   ├── components/     # UI components
│   │   ├── pages/          # Next.js pages
│   │   └── routes/         # Custom routing logic
│   ├── domain/             # Business logic and entities
│   │   ├── entities/       # Domain entities
│   │   ├── useCases/       # Business use cases
│   │   └── repositories/   # Interfaces for data repositories
│   ├── infrastructure/     # Data access and external services
│   │   ├── api/            # API service implementations
│   │   ├── db/             # Database access
│   │   └── thirdParty/     # Third-party integrations
│   ├── shared/             # Shared utilities and configurations
│   │   ├── utils/          # Utility functions
│   │   └── config/         # Configuration files
│   └── styles/             # Global styles
├── .gitignore
├── next.config.js
├── package.json
└── tsconfig.json
로그인 후 복사

6. 스토리북을 활용한 컴포넌트 중심 구조

스토리북을 사용한다는 것은 분리된 UI 컴포넌트를 체계적으로 테스트하고 개발하는 것입니다. 구성 요소 기능을 쉽게 테스트할 수 있습니다

my-next-app/
├── public/                 # Static files
├── src/
│   ├── components/         # UI components
│   │   ├── Button/         # Button component
│   │   │   ├── Button.tsx
│   │   │   ├── Button.stories.tsx
│   │   │   └── Button.test.tsx
│   │   └── Input/          # Input component
│   ├── pages/              # Next.js pages
│   ├── hooks/              # Custom hooks
│   ├── utils/              # Utility functions
│   ├── styles/             # Global styles
│   └── config/             # Configuration files
├── .storybook/             # Storybook configuration
│   ├── main.js
│   └── preview.js
├── .gitignore
├── next.config.js
├── package.json
└── tsconfig.json
로그인 후 복사

구조 선택 시 고려해야 할 요소

프로젝트 구조 선택은 다음과 같은 여러 요소에 따라 달라집니다.

  1. 프로젝트 규모: 프로젝트 규모가 큰 경우 프로젝트를 쉽게 관리하고 확장할 수 있는 구조를 선택하세요.
  2. 개발팀 규모: 팀 규모가 큰 경우 함께 작업하려면 각 부분을 명확하게 구분하는 구조를 선택해야 합니다
  3. 프로젝트 복잡성: 프로젝트가 복잡한 경우. 이러한 복잡성을 처리할 수 있는 구조를 선택해야 합니다
  4. 사용된 기술: Next.js, TypeScript, Storybook 등 사용된 기술은 적절하게 구성되어 권장될 수 있습니다

프로젝트 구조 모범 사례

  • 구성 요소를 작고 재사용 가능하게 유지: 구성 요소는 한 가지 일을 잘 수행해야 합니다.
  • 전체에서 구성요소 재사용

프로젝트.

  • 컨텍스트를 현명하게 사용: React Context API를 활용하여 동일한 데이터에 액세스해야 하는 구성 요소 전체의 상태를 관리하세요.
  • 스타일 구성: CSS 모듈 또는 모듈화를 위한 스타일 구성 요소를 사용하여 CSS/SASS 파일을 효율적으로 구성합니다.
  • 유형 안전성을 위해 TypeScript 활용: 유형 안전성과 더 나은 코드 가독성을 보장하기 위해 유형과 인터페이스를 정의합니다.
  • 작성 테스트: 기능을 보장하기 위해 구성 요소 및 유틸리티에 대한 단위 및 통합 테스트를 포함합니다.

고려할 도구

  • 스토리북: UI 컴포넌트 개발 및 테스트용
  • Jest: 코드 테스트 및 확인용
  • ESLint: 코드 확인 및 서식 지정
  • 더 예쁘다: 자동 코드 서식 지정
  • Husky & Lint-Staged: 사전 커밋 후크 설정
  • Next.js Custom Server: 서버 측 로직 사용

이 정보가 프런트엔드 개발에 적합한 프로젝트 구조를 선택하는 데 도움이 되기를 바랍니다!

위 내용은 프론트엔드 프로젝트 구조에는 몇 가지 유형이 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:dev.to
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿