컴퓨터 과학/🀰 디자인패턴

컴퓨터 과학/🀰 디자인패턴

MVVM 패턴

MVVM 패턴MVVM 패턴은 MVC의 C에 해당하는 컨트롤러가 뷰모델(view model)로 바뀐 패턴이다. 여기서 뷰모델은 뷰를 더 추상화한 계층이며, MVVM 패턴은 MVC 패턴과는 다르게 커맨드와 데이터 바인딩을 가지는 것이 특징이다. 뷰와 뷰모델 사이의 양방향 데이터 바인딩을 지원하며 UI를 별도의 코드 수정 없이 재사용할 수 있고 단위 테스팅하기 쉽다는 장점이 있다. MVVM 패턴의 예: 뷰MVVM 패턴을 가진 대표적인 프레임워크로는 뷰(Vue.js)가 있다. Vue.js는 반응형이 특징인 프런트엔드 프레임워크이다.  예를 들어 watch와 computed 등으로 쉽게 반응형적인 값들을 구축할 수 있다.함수를 사용하지 않고 값 대입만으로도 변수가 변경되며 양방향 바인딩, html을 토대로 컴포넌..

컴퓨터 과학/🀰 디자인패턴

MVP 패턴

MVP 패턴MVP 패턴은 MVC 패턴으로부터 파생되었으며 MVC에서 C에 해당하는 컨트롤러가 프레젠터로 교체된 패턴이다. 뷰와 프레젠터는 일대일 관계이기 때문에 MVC 패턴보다 더 강한 결합을 지닌 디자인 패턴이라고 볼 수 있다.

컴퓨터 과학/🀰 디자인패턴

MVC 패턴

MVC 패턴MVC 패턴은 모델(Model), 뷰(View), 컨트롤러(Controller)로 이루어진 디자인 패턴이다.애플리케이션의 구성 요소를 세 가지 역할로 구분하여 개발 프로세스에서 각각의 구성 요소에만 집중해서 개발할 수 있다. 재사용성과 확장성이 용이하다는 장점이 있고, 애플리케이션이 복잡해질수록 모델과 뷰의 관계가 복잡해지는 단점이 있다. 모델모델(model)은 애플리케이션의 데이터인 데이터베이스, 상수, 변수 등을 뜻한다.예를 들어 사각형 모양의 박스 안에 글자가 들어 있다면 그 사각형 모양의 박스 위치 정보, 글자 내용, 글자 위치, 글자 포맷(utf-8 등)에 관한 정보를 모두 가지고 있어야 한다. 뷰에서 데이터를 생성하거나 수정하면 컨트롤러를 통해 모델을 생성하거나 갱신한다. 뷰뷰(vi..

컴퓨터 과학/🀰 디자인패턴

노출모듈 패턴

노출모듈 패턴은 즉시 실행 함수를 통해 private, public 같은 접근 제어자를 만드는 패턴을 말한다. 자바스크립트는 private나 public 같은 접근 제어자가 존재하지 않고 전역 범위에서 스크립트가 실행된다. 그렇기 때문에 노출모듈 패턴을 통해 private와 public 접근 제어자를 구현하기도 한다.const pukuba = (() => { const a = 1 const b = () => 2 const public = { c : 2, d : () => 3 } return public })() console.log(pukuba)console.log(pukuba.a)// { c: 2, d: [Function: d] }// undefin..

컴퓨터 과학/🀰 디자인패턴

이터레이터 패턴

이터레이터 패턴이터레이터 패턴은 이터레이터(iterator)를 사용하여 컬렉션의 요소들에 접근하는 디자인 패턴이다.이를 통해 순회할 수 있는 여러 가지 자료형의 구조와는 상관없이 이터레이터라는 하나의 인터페이스로 순회가 가능하다. 자바스크립트에서의 이터레이터 패턴const mp = new Map() mp.set('a', 1)mp.set('b', 2)mp.set('cccc', 3) const st = new Set() st.add(1)st.add(2)st.add(3) const a = []for(let i = 0; i  분명히 다른 자료 구조인 set과 map임에도 똑같은 for  a of b 라는 이터레이터 프로토콜을 통해 순회하는 것을 볼 수 있다. 이터레이터 프로토콜 & 이터러블한 객체란?더보기이터레..

컴퓨터 과학/🀰 디자인패턴

프록시 패턴과 프록시 서버

프록시 패턴프록시 패턴은 대상 객체에 접근하기 전 그 접근에 대한 흐름을 가로체 대상 객체 앞단의 인터페이스 역할을 하는 디자인 패턴이다.이를 통해 객체의 속성, 변환 등을 보완하며 보안, 데이터 검증, 캐싱, 로깅에 사용한다.이는 앞서 설명한 프록시 객체로 쓰이기도 하지만 프록시 서버로도 활용된다. 프록시 서버에서의 캐싱이란?더보기 프록시 서버에서의 캐싱캐시 안에 정보를 담아두고, 캐시 안에 있는 정보를 요구하는 요청에 대해 다시 저 멀리 있는 원격 서버에 요청하지 않고 캐시 안에 있는 데이터를 활요하는 것을 말한다. 이를 통해 불필요하게 외부와 연결하지 않기 때문에 트래픽을 줄일 수 있다는 장점이 있다.프록시 서버프록시 서버는 서버와 클라이언트 사이에서 클라이언트가 자신을 통해 다른 네트워크 서비스에..

이재원
'컴퓨터 과학/🀰 디자인패턴' 카테고리의 글 목록