찾다
웹 프론트엔드JS 튜토리얼React의 견고한 원칙: 유지 관리 가능한 구성 요소 작성의 핵심

SOLID Principles in React: The Key to Writing Maintainable Components

React 애플리케이션이 성장함에 따라 구성 요소가 커지고 유지 관리하기 어려운 코드, 예상치 못한 버그 등 상황이 빠르게 지저분해질 수 있습니다. SOLID 원칙이 유용한 곳이 바로 여기입니다. 원래 객체 지향 프로그래밍을 위해 개발된 이러한 원칙은 깔끔하고 유연하며 확장 가능한 코드를 작성하는 데 도움이 됩니다. 이 기사에서는 각 SOLID 원칙을 분석하고 이를 React에서 사용하여 구성 요소를 체계적으로 유지하고 코드를 더 쉽게 유지 관리하며 앱이 성장할 수 있도록 준비하는 방법을 보여 드리겠습니다.

SOLID는 원래 객체 지향 프로그래밍을 위한 것이지만 React에도 적용할 수 있는 깨끗하고 유지 관리 가능하며 확장 가능한 코드 작성을 목표로 하는 5가지 디자인 원칙을 나타내는 약어입니다.

S: 단일 책임 원칙: 구성 요소에는 하나의 작업 또는 책임이 있어야 합니다.

O: 개방/폐쇄 원칙: 구성 요소는 확장을 위해 열려 있어야 하며 **(쉽게 향상되거나 사용자 정의될 수 있음) **수정을 위해 닫혀 있어야 합니다(핵심 코드에는 변경).

L: Liskov 대체 원칙: 구성 요소는 앱의 동작을 중단하지 않고 하위 구성 요소로 교체 가능해야 합니다.

I: 인터페이스 분리 원칙: 구성 요소는 사용하지 않는 기능에 종속되도록 강요해서는 안 됩니다.

D: 종속성 반전 원칙: 구성 요소는 구체적인 구현이 아닌 추상화에 의존해야 합니다.

단일 책임 원칙(SRP)

이렇게 생각해 보세요. 걷기와 같은 한 가지 작업만 수행할 수 있는 장난감 로봇이 있다고 상상해 보세요. 말하기와 같은 두 번째 작업을 요청하면 걷는 데 집중해야 하기 때문에 혼란스러워집니다! 다른 직업을 원한다면 두 번째 로봇을 구입하세요.

React에서 컴포넌트는 한 가지 작업만 수행해야 합니다. 데이터 가져오기, 양식 입력 처리, UI 표시 등 너무 많은 작업을 한꺼번에 수행하면 지저분해지고 관리가 어려워집니다.

const UserCard = () => {
  const [user, setUser] = useState(null);

  useEffect(() => {
    fetch('/api/user')
      .then(response => response.json())
      .then(data => setUser(data));
  }, []);

  return user ? ( <div>
      <h2 id="user-name">{user.name}</h2>
      <p>{user.email}</p>
    </div> ) : <p>Loading...</p>;
};

여기서 UserCard는 데이터 가져오기와 UI 렌더링을 담당하며, 이는 단일 책임 원칙을 위반합니다.

const useFetchUser = (fetchUser) => {
  const [user, setUser] = useState(null);

  useEffect(() => {
    fetchUser().then(setUser);
  }, [fetchUser]);

  return user;
};

const UserCard = ({ fetchUser }) => {
  const user = useFetchUser(fetchUser);

  return user ? (
    <div>
      <h2 id="user-name">{user.name}</h2>
      <p>{user.email}</p>
    </div>
  ) : (
    <p>Loading...</p>
  );
};

여기서 데이터 가져오기 로직은 사용자 정의 후크(useFetchUser)로 이동하는 반면 UserCard는 UI 렌더링 및 SRP 유지에만 집중합니다.

개방형/폐쇄형 원리(OCP)

비디오 게임 캐릭터를 생각해 보세요. 핵심 능력(수정)을 변경하지 않고도 캐릭터에 새로운 기술(확장)을 추가할 수 있습니다. 이것이 바로 OCP의 목적입니다. 이미 존재하는 코드를 변경하지 않고도 코드를 확장하고 조정할 수 있도록 하는 것입니다.

const Alert = ({ type, message }) => {
  if (type === 'success') {
    return <div classname="alert-success">{message}</div>;
  }
  if (type === 'error') {
    return <div classname="alert-error">{message}</div>;
  }
  return <div>{message}</div>;
};

여기서 새로운 경고 유형이 필요할 때마다 OCP를 손상시키는 경고 구성 요소를 수정해야 합니다. 구성 요소에 조건부 렌더링을 추가하거나 케이스 렌더링을 전환할 때마다 해당 구성 요소의 유지 관리가 어려워지므로 기능에 더 많은 조건을 추가하고 OCP를 손상시키는 구성 요소 핵심 코드를 수정해야 합니다.

const Alert = ({ className, message }) => (
  <div classname="{className}">{message}</div>
);

const SuccessAlert = ({ message }) => (
  <alert classname="alert-success" message="{message}"></alert>
);

const ErrorAlert = ({ message }) => (
  <alert classname="alert-error" message="{message}"></alert>
);

이제 Alert 구성 요소는 확장을 위해 열려 있습니다(SuccessAlert, ErrorAlert 등을 추가하여). 하지만 핵심 Alert 구성 요소를 건드릴 필요가 없기 때문에 수정을 위해 닫혀 있습니다. 새로운 경고 유형을 추가합니다.

OCP를 원하시나요? 상속보다 구성을 선호

Liskov 대체 원칙(LSP)

휴대폰이 있는데 새 스마트폰을 갖게 되었다고 상상해 보세요. 일반 전화기에서 했던 것처럼 스마트폰에서도 전화를 걸기를 기대합니다. 스마트폰이 전화를 못 걸면 나쁜 대체품이겠죠? 이것이 바로 LSP의 목적입니다. 새 구성 요소나 하위 구성 요소는 문제를 일으키지 않고 원본처럼 작동해야 합니다.

const Button = ({ onClick, children }) => (
  <button onclick="{onClick}">{children}</button>
);

const IconButton = ({ onClick, icon }) => (
  <button onclick="{onClick}">
    <i classname="{icon}"></i>
  </button>
);

여기서 Button을 IconButton으로 바꾸면 레이블이 손실되어 동작과 기대가 깨집니다.

const Button = ({ onClick, children }) => (
  <button onclick="{onClick}">{children}</button>
);

const IconButton = ({ onClick, icon, label }) => (
  <button onclick="{onClick}">
    <i classname="{icon}"></i> {label}
  </button>
);

// IconButton now behaves like Button, supporting both icon and label

이제 IconButton은 Button의 동작을 적절하게 확장하여 아이콘과 라벨을 모두 지원하므로 기능을 중단하지 않고 교체할 수 있습니다. 이는 자식(IconButton)이 부모(Button)를 아무런 문제 없이 대체할 수 있기 때문에 Liskov 대체 원칙을 따릅니다!

B 구성 요소가 A 구성 요소를 확장하는 경우 A 구성 요소를 사용하는 모든 위치에서 B 구성 요소를 사용할 수 있습니다.

인터페이스 분리 원칙(ISP)

리모컨을 사용하여 TV를 시청한다고 상상해 보세요. 전원, 볼륨, 채널과 같은 몇 개의 버튼만 있으면 됩니다. 리모컨에 DVD 플레이어, 라디오, 조명 등 불필요한 버튼이 너무 많다면 사용하기 불편할 것입니다.

이를 사용하는 구성 요소가 소품을 모두 필요로 하지 않더라도 많은 소품을 사용하는 데이터 테이블 구성 요소가 있다고 가정해 보겠습니다.

const DataTable = ({ data, sortable, filterable, exportable }) => (
  <div>
    {/* Table rendering */}
    {sortable && <button>Sort</button>}
    {filterable && <input placeholder="Filter">}
    {exportable && <button>Export</button>}
  </div>
);

This component forces all consumers to think about sorting, filtering, and exporting—even if they only want a simple table.

You can split the functionality into smaller components based on what’s needed.

const DataTable = ({ data }) => (
  <div>
    {/* Table rendering */}
  </div>
);

const SortableTable = ({ data }) => (
  <div>
    <datatable data="{data}"></datatable>
    <button>Sort</button>
  </div>
);

const FilterableTable = ({ data }) => (
  <div>
    <datatable data="{data}"></datatable>
    <input placeholder="Filter">
  </div>
);

Now, each table only includes the functionality that’s needed, and you’re not forcing unnecessary props everywhere. This follows ISP, where components only depend on the parts they need.

Dependency Inversion Principle (DIP)

Imagine you're building with LEGO blocks. You have a robot built with specific pieces. But what if you want to swap out its arms or legs? You shouldn't have to rebuild the whole thing—just swap out the parts. The Dependency Inversion Principle (DIP) is like this: your robot (high-level) doesn't depend on specific parts (low-level); it depends on pieces that you can change easily.

const UserComponent = () => {
  useEffect(() => {
    fetch('/api/user').then(...);
  }, []);
  return <div>...</div>;
};

This directly depends on fetch—you can’t swap it easily.

const UserComponent = ({ fetchUser }) => {
  useEffect(() => {
    fetchUser().then(...);
  }, [fetchUser]);
  return <div>...</div>;
};

Now, the fetchUser function is passed in, and you can easily swap it with another implementation (e.g., mock API, or another data source), keeping everything flexible and testable.

Final Thoughts

Understanding and applying SOLID principles in React can drastically improve the quality of your code. These principles—Single Responsibility, Open/Closed, Liskov Substitution, Interface Segregation, and Dependency Inversion—help you write components that are more modular, flexible, and easier to maintain. By breaking down responsibilities, keeping code extensible, and making sure each part of your app interacts in predictable ways, you can create React applications that scale more easily and are simpler to debug. In short, SOLID principles lead to cleaner and more maintainable codebases.

위 내용은 React의 견고한 원칙: 유지 관리 가능한 구성 요소 작성의 핵심의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
JavaScript로 문자열 문자를 교체하십시오JavaScript로 문자열 문자를 교체하십시오Mar 11, 2025 am 12:07 AM

JavaScript 문자열 교체 방법 및 FAQ에 대한 자세한 설명 이 기사는 JavaScript에서 문자열 문자를 대체하는 두 가지 방법 인 내부 JavaScript 코드와 웹 페이지의 내부 HTML을 탐색합니다. JavaScript 코드 내부의 문자열을 교체하십시오 가장 직접적인 방법은 대체 () 메소드를 사용하는 것입니다. str = str.replace ( "find", "replace"); 이 메소드는 첫 번째 일치 만 대체합니다. 모든 경기를 교체하려면 정규 표현식을 사용하고 전역 플래그 g를 추가하십시오. str = str.replace (/fi

자신의 Ajax 웹 응용 프로그램을 구축하십시오자신의 Ajax 웹 응용 프로그램을 구축하십시오Mar 09, 2025 am 12:11 AM

그래서 여기 당신은 Ajax라는이 일에 대해 배울 준비가되어 있습니다. 그러나 정확히 무엇입니까? Ajax라는 용어는 역동적이고 대화식 웹 컨텐츠를 만드는 데 사용되는 느슨한 기술 그룹을 나타냅니다. 원래 Jesse J에 의해 만들어진 Ajax라는 용어

10 JQuery Fun 및 Games 플러그인10 JQuery Fun 및 Games 플러그인Mar 08, 2025 am 12:42 AM

10 재미있는 jQuery 게임 플러그인 웹 사이트를보다 매력적으로 만들고 사용자 끈적함을 향상시킵니다! Flash는 여전히 캐주얼 웹 게임을 개발하기위한 최고의 소프트웨어이지만 JQuery는 놀라운 효과를 만들 수 있으며 Pure Action Flash 게임과 비교할 수는 없지만 경우에 따라 브라우저에서 예기치 않은 재미를 가질 수 있습니다. jQuery tic 발가락 게임 게임 프로그래밍의 "Hello World"에는 이제 jQuery 버전이 있습니다. 소스 코드 jQuery Crazy Word Composition 게임 이것은 반은 반은 게임이며, 단어의 맥락을 알지 못해 이상한 결과를 얻을 수 있습니다. 소스 코드 jQuery 광산 청소 게임

jQuery 시차 자습서 - 애니메이션 헤더 배경jQuery 시차 자습서 - 애니메이션 헤더 배경Mar 08, 2025 am 12:39 AM

이 튜토리얼은 jQuery를 사용하여 매혹적인 시차 배경 효과를 만드는 방법을 보여줍니다. 우리는 멋진 시각적 깊이를 만드는 계층화 된 이미지가있는 헤더 배너를 만들 것입니다. 업데이트 된 플러그인은 jQuery 1.6.4 이상에서 작동합니다. 다운로드

내 자신의 JavaScript 라이브러리를 어떻게 작성하고 게시합니까?내 자신의 JavaScript 라이브러리를 어떻게 작성하고 게시합니까?Mar 18, 2025 pm 03:12 PM

기사는 JavaScript 라이브러리 작성, 게시 및 유지 관리, 계획, 개발, 테스트, 문서 및 홍보 전략에 중점을 둡니다.

브라우저에서 성능을 위해 JavaScript 코드를 최적화하려면 어떻게해야합니까?브라우저에서 성능을 위해 JavaScript 코드를 최적화하려면 어떻게해야합니까?Mar 18, 2025 pm 03:14 PM

이 기사는 브라우저에서 JavaScript 성능을 최적화하기위한 전략에 대해 설명하고 실행 시간을 줄이고 페이지로드 속도에 미치는 영향을 최소화하는 데 중점을 둡니다.

jQuery 및 Ajax를 사용한 자동 새로 고침 DIV 컨텐츠jQuery 및 Ajax를 사용한 자동 새로 고침 DIV 컨텐츠Mar 08, 2025 am 12:58 AM

이 기사에서는 jQuery 및 Ajax를 사용하여 5 초마다 DIV의 컨텐츠를 자동으로 새로 고치는 방법을 보여줍니다. 이 예제는 RSS 피드의 최신 블로그 게시물을 마지막 새로 고침 타임 스탬프와 함께 가져오고 표시합니다. 로딩 이미지는 선택 사항입니다

Matter.js : 소개를 시작합니다Matter.js : 소개를 시작합니다Mar 08, 2025 am 12:53 AM

Matter.js는 JavaScript로 작성된 2D 강성 신체 물리 엔진입니다. 이 라이브러리를 사용하면 브라우저에서 2D 물리학을 쉽게 시뮬레이션 할 수 있습니다. 그것은 단단한 몸체를 생성하고 질량, 면적 또는 밀도와 같은 물리적 특성을 할당하는 능력과 같은 많은 기능을 제공합니다. 중력 마찰과 같은 다양한 유형의 충돌 및 힘을 시뮬레이션 할 수도 있습니다. Matter.js는 모든 주류 브라우저를 지원합니다. 또한, 터치를 감지하고 반응이 좋기 때문에 모바일 장치에 적합합니다. 이러한 모든 기능을 사용하면 엔진 사용 방법을 배울 수있는 시간이 필요합니다. 이는 물리 기반 2D 게임 또는 시뮬레이션을 쉽게 만들 수 있습니다. 이 튜토리얼에서는 설치 및 사용을 포함한이 라이브러리의 기본 사항을 다루고

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

맨티스BT

맨티스BT

Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

MinGW - Windows용 미니멀리스트 GNU

MinGW - Windows용 미니멀리스트 GNU

이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

SublimeText3 영어 버전

SublimeText3 영어 버전

권장 사항: Win 버전, 코드 프롬프트 지원!

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경