MVVM – 소개
코드를 구성하는 가장 잘 정리되고 재사용 가능한 방법은 'MVVM'패턴을 사용하는 것입니다. 그만큼Model, View, ViewModel (MVVM pattern) 유지 관리, 테스트 및 확장 가능한 응용 프로그램을 작성하기 위해 코드를 구성하고 구성하는 방법을 안내합니다.
Model − 단순히 데이터를 보유하고 비즈니스 로직과 아무 관련이 없습니다.
ViewModel − Model과 View 사이의 연결 / 연결 역할을하며 물건을 예쁘게 만듭니다.
View − 단순히 형식화 된 데이터를 보유하고 본질적으로 모든 것을 모델에 위임합니다.
분리 된 프레젠테이션
응용 프로그램 논리를 코드 숨김 또는 XAML에 배치하여 발생하는 문제를 방지하려면 분리 된 프레젠테이션이라는 기술을 사용하는 것이 가장 좋습니다. 사용자 인터페이스 개체로 직접 작업하는 데 필요한 최소한의 XAML 및 코드 숨김을 사용하여이를 방지하려고합니다. 사용자 인터페이스 클래스에는 또한 왼쪽의 다음 그림과 같이 복잡한 상호 작용 동작, 응용 프로그램 논리 및 기타 모든 것에 대한 코드가 포함되어 있습니다.
분리 된 프리젠 테이션을 사용하면 사용자 인터페이스 클래스가 훨씬 간단 해집니다. 물론 XAML이 있지만 그 뒤에있는 코드는 실제적인 작업을 거의 수행하지 않습니다.
애플리케이션 로직은 종종 모델이라고하는 별도의 클래스에 속합니다.
그러나 이것은 전체 이야기가 아닙니다. 여기서 멈 추면 데이터 바인딩 광기의 길로 이끄는 매우 일반적인 실수를 반복 할 수 있습니다.
많은 개발자가 데이터 바인딩을 사용하여 XAML의 요소를 모델의 속성에 직접 연결하려고합니다.
이제 때때로 이것은 괜찮을 수 있지만 종종 그렇지 않습니다. 문제는 모델이 사용자가 응용 프로그램과 상호 작용하는 방식이 아니라 응용 프로그램이 수행하는 문제와 전적으로 관련되어 있다는 것입니다.
데이터를 제시하는 방식은 내부적으로 구조화 된 방식과 다소 다릅니다.
또한 대부분의 사용자 인터페이스에는 애플리케이션 모델에 속하지 않는 일부 상태가 있습니다.
예를 들어 사용자 인터페이스에서 드래그 앤 드롭을 사용하는 경우 항목이 지금 드래그되는 위치, 가능한 드롭 대상 위로 이동할 때 모양이 어떻게 변경되어야하는지, 드롭 대상이 어떻게 될 수 있는지 등을 추적해야합니다. 항목을 드래그하면 변경됩니다.
이러한 종류의 상태는 놀라 울 정도로 복잡해질 수 있으며 철저한 테스트가 필요합니다.
실제로는 일반적으로 사용자 인터페이스와 모델 사이에 다른 클래스가 있어야합니다. 여기에는 두 가지 중요한 역할이 있습니다.
첫째, 특정 사용자 인터페이스보기에 맞게 애플리케이션 모델을 조정합니다.
둘째, 사소한 상호 작용 논리가 존재하는 곳입니다. 즉, 사용자 인터페이스가 원하는 방식으로 작동하도록하는 데 필요한 코드를 의미합니다.