정처기 감자
SW 설계디자인패턴

검색

검색어를 입력해 개념, 문제, 필기를 찾습니다.

추상 팩토리 abstract factory 패턴 - 자바스크립트 예제

SW설계디자인패턴
읽는데 4분 소요
처음 쓰여진 날: 2025-09-02
마지막 수정일: 2025-09-02
조회수: —
선수학습(2개)
  • 정보처리기사 실기를 위한 디자인 패턴 암기 방법
  • 팩토리 메서드 factory method 패턴 - 자바스크립트 예제

요약

추상 팩토리 abstract factory 패턴을 자바스크립트 코드와 함께 알아봅니다.

추상 팩토리 (Abstract Factory) 패턴 요약

패턴 종류핵심 키워드
추상 팩토리 (Abstract Factory)조합을 만드는 인터페이스(API) 제공, Kit
추상 팩토리 패턴 감자
추상 팩토리 패턴 감자

추상 팩토리 (Abstract Factory) 패턴

추상 팩토리 패턴은 서로 관련이 있거나 의존적인 객체들의 집합을 생성하기 위한 인터페이스를 제공하되, 구체적인 클래스는 지정하지 않는 패턴입니다. 팩토리 메서드 패턴이 단일 객체를 생성하는 것에 초점을 맞춘다면, 추상 팩토리는 '제품군(Family of Products)'을 생성하는 데 사용됩니다.

가장 흔한 예는 UI 컴포넌트의 테마(Theme)를 관리하는 것입니다. 라이트 모드와 다크 모드에 따라 버튼, 체크박스, 창(Window) 등 여러 UI 요소가 일관된 스타일을 가져야 합니다.


기본 구조

javascript
코드 하이라이팅 중…

팩토리 메서드 vs. 추상 팩토리

  • 팩토리 메서드: 하나의 Creator 클래스가 상속을 통해 하나의 제품을 생성하는 방법을 변경합니다.
  • 추상 팩토리: 여러 제품군을 생성하는 인터페이스를 제공합니다. 클라이언트는 구체적인 제품 클래스를 알 필요 없이, 팩토리만 교체하면 전체 제품군을 한 번에 바꿀 수 있습니다.

추상 팩토리 패턴 중요 키워드

  • 관련 객체들의 '가족(family)'을 생성한다.
  • 클라이언트 코드는 구체적인 클래스에 의존하지 않는다.
  • 전체 제품군을 쉽게 교체할 수 있다.
  • 사용자에게 API를 제공하고, 구체적인 구현은 Concrete Product 클래스에서 이루어진다.

'API 제공'과 '구체적 구현'의 의미

여기서 "사용자에게 API를 제공한다"는 말의 '사용자'는 실제 사람이 아닌, 팩토리를 가져다 쓰는 코드(클라이언트 코드) 를 의미합니다.

  • API 제공 (추상 클래스): GUIFactory, Button, Checkbox 같은 추상 클래스는 일종의 '계약서' 또는 '설명서' 역할을 합니다. 클라이언트 코드(renderUI 함수)는 이 '설명서'만 보고 createButton()이나 paint() 같은 메서드를 호출합니다. 클라이언트는 LightButton이나 DarkButton의 실제 구현을 전혀 알 필요가 없습니다.
  • 구체적 구현 (Concrete 클래스): LightThemeFactory나 DarkButton 같은 Concrete 클래스는 '계약서'의 내용을 실제로 이행하는 '실무자'입니다. createButton() 요청이 오면 실제 라이트/다크 테마 버튼 객체를 생성하고, paint() 요청이 오면 실제 테마에 맞는 스타일을 그리는 로직을 수행합니다.

결론적으로, 클라이언트 코드는 구체적인 클래스 이름(LightButton)을 코드에 직접 쓸 필요 없이, 추상적인 '설명서(API)'에만 의존하게 됩니다. 덕분에 팩토리만 교체하면 전체 제품군(테마)을 한 번에 바꿀 수 있는 유연한 구조가 만들어집니다.

메가커피와 함께, 홈페이지 개선에 참여하세요! ☕
혹시 이용에 불편한 점이나 개선이 필요한 부분을 발견하셨나요? 댓글로 알려주시면 더 나은 감자가 될 수 있어요! 🥔 제보해주신 모든 분께 메가커피 기프티콘을 드립니다! (본인 이메일로 댓글 달아주셔야해요~)
후수학습(1개)
  • 디자인 패턴 정보처리기사 기출 문제 모음

추천 개념

Beta

관련 글

(41개)
제목태그업데이트시험
빌더 builder 패턴 - 자바스크립트 예제
디자인패턴SW설계디자인패턴
2025-09-02-
팩토리 메서드 factory method 패턴 - 자바스크립트 예제
디자인패턴SW설계디자인패턴
2025-11-03-
프로토타입 prototype 패턴 - 자바스크립트 예제
디자인패턴SW설계디자인패턴
2025-09-02-
정처기 감자정처기 감자

정보처리기사 합격
도와줄라고 하는 감자

실기 이론

  • 이론 공부법
  • DB
  • 네트워크/OS
  • SW 설계
  • SW 개발
  • 보안/신기술

시험 응시

  • 시험장 찾기
  • 원서 접수
  • 응시자격 서류

요약 PDF

  • 26년 1회 이론 압축
  • 초압축 25년 3회
  • 압축 25년 3회

기출문제

  • 전체 기출문제
  • 25년 3회
  • 25년 2회
  • 문제 포럼

감자 이용권

  • 이용권 구매

실기 이론

  • 이론 공부법
  • DB
  • 네트워크/OS
  • SW 설계
  • SW 개발
  • 보안/신기술

시험 응시

  • 시험장 찾기
  • 원서 접수
  • 응시자격 서류

요약 PDF

  • 26년 1회 이론 압축
  • 초압축 25년 3회
  • 압축 25년 3회

기출문제

  • 전체 기출문제
  • 25년 3회
  • 25년 2회
  • 문제 포럼

감자 이용권

  • 이용권 구매
© 2025 재현기획개발. All rights reserved.
  • 정처기 감자의 시작
  • 업데이트 로그
  • 개인정보 처리방침
  • 이용약관
상호명 : 재현기획개발 / 주소: 서울특별시 영등포구 영등포로 150, 지하1층 108호 L145 가라지(당산동1가, 생각공장 당산) / 대표: 김재현 / 전화: 010-8158-7127 / 통신판매업신고: 제2025-서울영등포-1569호 / 이메일: contact@edugamja.com / 사업자등록번호: 573-51-00999