Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[신승준] 챕터 7: 자바스크립트 디자인 패턴 (3/3) #68

Open
wants to merge 1 commit into
base: main
Choose a base branch
from
Open
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
56 changes: 56 additions & 0 deletions 챕터_7/신승준.md
Original file line number Diff line number Diff line change
Expand Up @@ -259,3 +259,59 @@ student.study(); // any;
> JavaScript에서 구현된 Interface 코드를 찾아봤읍니다. 무려 10년 전!

[JavaScript에서 구현한 Interface](https://github.com/RestlessThinker/Javascript-Interface/blob/master/interface.js)

### 플라이웨이트 패턴

연관된 객체끼리 데이터를 공유하게 하면서 애플리케이션의 메모리를 최소화하는 패턴.

> [디자인패턴, Flyweight Pattern, 플라이 웨이트 패턴](https://www.youtube.com/watch?v=oRThakO5o-Q) 이 영상의 예시가 조금 더 쉬워서 이해하기 수월했어요.

Comment on lines +266 to +268
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

🐷 🐷 🐷

> 매번 데이터를 생성하기 보다는, 공유될 수 있고 중복되지 않아도 되는 것들은 다른 클래스나 객체로 분리하고 이를 사용해 메모리 사용을 최소화한다.

- 중앙 집중식 이벤트 핸들링

여러 요소들에 하나하나 이벤트를 바인딩하기 보다는 최상위 컨테이너에 이벤트를 한 번만 바인딩한다.

> 한창 자바스크립트 공부할 때 이런 방식을 자주 접하곤 했는데 막상 실무에선 써보지 않았네요. 이런 방식으로 최적화해보신 분..!?

## 행위 패턴

객체 간의 의사소통을 다룬다.

### 관찰자 패턴

한 객체가 변경될 때 이를 구독하고 있는 다른 객체들에게 변경되었음을 알린다.

### 발행/구독 패턴

이벤트를 발생시키는 발행자와 그 이벤트를 구독하는 구독자 사이에 토픽/이벤트 채널이 있음.

발행자와 구독자를 각자 독립적으로 유지함. 그리고 느슨한 결합을 도모함.

### 중재자 패턴

시스템의 구성 요소들 간에 직접적인 관계가 너무 많다면, 중앙 통제 포인트를 두어 모든 구성 요소들이 이를 통해 간접적으로 소통하도록 할 때가 되었다.

```typescript
const queryClient = new QueryClient({
queryCache: new QueryCache({
onError: (error) => {
...
},
}),
});
```

> 요런 친구도 중재자 패턴이라고 할 수 있을까요? 하위 ErrorBoundary에서 걸러지지 않은 에러들은 이렇게 최상위의 query client에서 처리해주고 있는디.
Comment on lines +295 to +305
Copy link
Contributor

@sangbooom sangbooom Nov 12, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

제 생각엔 퍼사드 패턴 같아요!
QueryClient가 퍼사드 역할을 하고 내부적으로는 QueryCache와 다른 요소들이 함께 작동한다는 점이 퍼사드 패턴이지 않을까 생각이 드네요 🤔

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

둘 다 아닐까요?

QueryClient라는 중재자를 두어 에러처리를 중앙에서 처리하니까 개별 컴포넌트간의 의존성과 결합도를 낮출 수 있는거고, onError같은 핸들러는 복잡한 구현을 숨기고 사용성이 좋은 인터페이스만 노출하니까 퍼사드라고 볼 수 있을 것 같아요

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

두분 다 쩌시네요

저는 그냥 코드 더미로만 보이는데


### 이벤트 집한 패턴과 중재자 패턴 결합하기

> 세부 로직은 중재자한테 위임할건데, 그 방식은 이벤트 집한 패턴으로 하겠뜸! 정도로만 이해했읍니다...

### 커맨드 패턴

객체 내부의 핵심 API가 변경되면 이 API를 사용하는 모든 객체를 수정해야 한다.

커맨드 패턴에서는 execute와 같은 실행을 위한 동작을 포함하는 커맨드 객체와, execute 메서드에 의해 실행할 동작을 가지고 있는 객체로 구성된다.

> 근데 예시에서 CarManager의 메서드 이름만 변경되어도, 해당 메서드를 사용하고 있는 코드들도 수정해야 되지 않나요??
Loading