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

검색

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

데코레이터 decorator 패턴 - 자바스크립트 예제

SW설계디자인패턴
읽는데 4분 소요
처음 쓰여진 날: 2025-09-01
마지막 수정일: 2025-09-01
조회수: —
선수학습(1개)
  • 정보처리기사 실기를 위한 디자인 패턴 암기 방법

요약

데코레이터 decorator 패턴을 자바스크립트 코드와 함께 알아봅니다. 정보처리기사 대비 문제가 포함되어있습니다.

데코레이터 패턴 요약

패턴 종류핵심 키워드
데코레이터 (Decorator)동적으로 기능 추가, 객체 조합, 상속의 대안
데코레이터 패턴 감자
데코레이터 패턴 감자

데코레이터 (Decorator) 패턴

데코레이터 패턴은 객체의 기존 코드를 수정하지 않고도 동적으로 새로운 기능이나 책임을 추가할 수 있게 해주는 구조 패턴입니다. 이름처럼 객체를 장식(decorate)하여 기능을 확장하는 방식입니다. 상속을 통해 기능을 확장할 수도 있지만, 상속은 정적인 방식이라 모든 조합에 대한 서브클래스를 만들어야 하는 '클래스 폭발(class explosion)' 문제를 야기할 수 있습니다. 데코레이터 패턴은 이러한 문제를 해결하는 유연한 대안입니다.

현실 세계의 예로 '커피 주문'을 생각해볼 수 있습니다. 기본 커피(아메리카노)에 우유를 추가하고(카페라떼), 거기에 시럽을 추가하고(바닐라 라떼), 휘핑 크림을 올리는(아인슈페너)처럼, 기본 객체에 여러 '장식(옵션)'을 동적으로 추가해 새로운 객체를 만드는 것과 같습니다.

기본 구조

데코레이터 패턴은 다음 요소들로 구성됩니다.

  • Component: 장식될 객체와 장식하는 객체(데코레이터)가 모두 구현해야 할 공통 인터페이스(또는 추상 클래스)입니다.
  • ConcreteComponent: 장식의 대상이 되는 핵심 기능을 가진 구체적인 클래스입니다. (예: 기본 커피)
  • Decorator: Component 인터페이스를 구현하면서, 내부에 Component 객체에 대한 참조를 가집니다. 이 참조를 통해 장식할 객체와 연결됩니다.
  • ConcreteDecorator: Decorator를 상속받아 실제로 새로운 기능이나 책임을 추가하는 클래스입니다. (예: 우유 추가, 시럽 추가)

예시: 커피 주문 시스템

다양한 옵션을 추가할 수 있는 커피 주문 시스템을 만들어 보겠습니다.

먼저 모든 커피 객체가 따를 Coffee 인터페이스(여기서는 클래스로 정의)를 만듭니다.

javascript
코드 하이라이팅 중…

가장 기본이 되는 커피, SimpleCoffee를 만듭니다.

javascript
코드 하이라이팅 중…

이제 데코레이터의 기반이 될 추상 클래스를 만듭니다. 이 클래스는 다른 Coffee 객체를 감쌀(wrap) 것입니다.

javascript
코드 하이라이팅 중…

이제 구체적인 데코레이터들을 만듭니다. WithMilk와 WithSugar는 각각 우유와 설탕을 추가하는 역할을 합니다.

javascript
코드 하이라이팅 중…

이처럼 데코레이터 패턴을 사용하면, SimpleCoffee 클래스를 전혀 수정하지 않고도 WithMilk, WithSugar 같은 새로운 기능을 동적으로 계속 추가할 수 있습니다. 만약 '휘핑 크림 추가', '샷 추가' 등의 기능이 필요하다면 새로운 데코레이터 클래스만 만들어주면 됩니다.

데코레이터 패턴 중요 키워드

  • 객체를 감싸서(wrap) 새로운 책임을 추가합니다.
  • 객체의 결합(SimpleCoffee, WithMilk, WithSugar)을 통해 기능을 확장합니다.
  • 상속의 유연한 대안입니다.
  • 동적으로 기능을 추가하거나 제거할 수 있습니다.
  • 핵심 기능과 추가 기능이 동일한 인터페이스를 따릅니다.
  • 데코레이터의 순서가 결과에 영향을 줄 수 있습니다.
메가커피와 함께, 홈페이지 개선에 참여하세요! ☕
혹시 이용에 불편한 점이나 개선이 필요한 부분을 발견하셨나요? 댓글로 알려주시면 더 나은 감자가 될 수 있어요! 🥔 제보해주신 모든 분께 메가커피 기프티콘을 드립니다! (본인 이메일로 댓글 달아주셔야해요~)
후수학습(1개)
  • 디자인 패턴 정보처리기사 기출 문제 모음

추천 개념

Beta

관련 글

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

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

실기 이론

  • 이론 공부법
  • 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