JavaScript/Vue

Vue.js 알아보기 - MVVM 패턴, MVC 패턴 그리고 그 외

Kani Kim 2023. 1. 9. 21:19

What is MVC?

MVC에 대해서 들어보신 분은 많을 것이다. Model-View-Controller의 약자로 보통 Spring에서 쓰던 패턴이다. 간단하게 여기서 MVC 패턴에 대해 설명하고 가면 다음과 같다.

  • Model : 일반적인 MVC 패턴에서는 비즈니스와 도메인 로직을 표방하며 데이터베이스를 포함하고 있을 수 있다.
  • View : 정보를 유저에게 보여주는 역할을 한다.
  • Controller : 중간자 역할을 한다. 모델로 부터 받은 데이터를 변환 및 모으고, 이벤트에 대해 적절하게 라우팅 및 변환을 하여 View에게 전달한다.

많은 웹 프레임워크들이 이 MVC패턴을 자유롭게 변형해서 사용한다. 이러한 MVC패턴은 다음과 같이 동작한다.

  1. User의 액션이 Controller에 들어온다.
  2. Controller가 User의 액션 혹은 이벤트를 확인하고 Model을 업데이트한다.
  3. Controller가 Model을 나타낼 View를 선택한다.
  4. View에서 Model을 이용해 화면을 보여준다. 

이러한 MVC의 장점으로는 다음과 같은 특징들이 있다.

  • 빠른 개발 속도
  • 여러 화면(View) 제공 능력
  • 비동기 프로세스 지원
  • 일부 변경이 전체에 반영되지 않음

반면 단점으로는 다음과 같은 특징이 있다.

  • 복잡한 구성으로 인해 개발 난이도가 높다
  • 작은 어플리케이션에는 적용하기 힘들다
  • 각각의 독립적인 개발(UI개발, 비즈니스 로직 개발 등등)로 인한 개발 지연 

이정도로 MVC에 대해 알아봤다. 그렇다면 오늘의 주인공인 MVVM에 대해 본격적으로 알아볼 시간이다.

 

What is MVVM?

MVVM은 Model-View-View-Model의 줄임말로 각각 다음의 역할을 한다.

  • View : 유저가 보는 UI부분이다. 기존의 MVC에 있던 "의사 결정 로직"은 모두 View-Model로 옮겨졌다. 다만 현재 Application State에 따른 데이터의 존재에 따라 내용을 렌더링한다.

보통 실제 코드에서 View는 DOM으로 보면 된다.

  • Data Binding : Binder의 경우 데이터를 View에다가 속성으로써 보여준다. View는 Binder를 통해 이 데이터를 보여주며, View-Model에 Store에 저장되어 있는 데이터를 View에 연결해주는 역할을 한다. 
  • View-Model : Store라고 불리는 객체안에 있는 Application 데이터를 유지한다. Store는 Application이 요구하는 모든 데이터를 가지고 있다.

보통 실제 코드에서는 View-Model은 Vue로 보면 된다.

  • Model : Application 데이터를 계속 가지고 있으며, 비즈니스 로직이나, 모델 로직 등을 품고있다.

보통 실제 코드에서는 Javasciprt 객체라고 보면 된다.

 

좀 더 설명하자면, MVVM 패턴에서 Model과 View는 기존 MVC패턴에서와 같이 비슷하게 작동한다. 그렇다면 Controller 역할을 하는 것처럼 View-Model레이어는 무엇을 할까? 결론적으로 View에서 Model 레이어를 좀 더 잘 사용할 수 있게 Bridge역할을 하는 것이라 보면 된다. View-Model에서는 Controller처럼 View에서 받은 메시지를 Model에 잘 변환해서 전달한다. 더 나아가, View-Model의 속성이 바뀌면 View는 그 변화를 듣고서/감지하고서 보여주는 부분을 적절하게 업데이트한다.

 

MVVM in Vue.js

만약 우리가 Vue.js를 통해 프론트 사이드를 만들었다고 하고, 서버쪽 API를 쓴다고 해보자. Model쪽은 아마 상태 관리 툴인 Vuex나 Axios로 - 서버쪽 API에게서 데이터를 받거나 주는 역할 - 되어있다고 하자.  View-Model 레이어는 나중에 설명할, 계산되고 반응형 속성, 메소드를 제공하는 컴포넌트 정의를 통해 실행되며, 이 레이어는 View에다가 데이터나 기능을 제공한다. 

 

이번 글에서는 MVVM에 대해서 알아봤다. 다음 글에서는 Component와 DOM에 대해서 알아보려고 한다.

 

 

 

 

728x90
반응형