MVVM – 인터뷰 질문
Model, View, ViewModel (MVVM 패턴)은 유지 관리, 테스트 및 확장 가능한 애플리케이션을 작성하기 위해 코드를 구성하고 구조화하는 방법을 안내합니다.
Model − 단순히 데이터를 보유하고 비즈니스 로직과 아무 관련이 없습니다.
ViewModel − Model과 ViewModel 간의 연결 / 연결 역할을하여 물건을 예쁘게 만듭니다.
View − 단순히 형식이 지정된 날짜를 보유하고 본질적으로 모든 것을 모델에 위임합니다.
주요 이점은 분리와이를 통해 얻는 효율성을 넘어서 뷰와 모델 간의 진정한 분리를 허용한다는 것입니다. 이것이 의미하는 바는 모델을 변경해야 할 때 뷰없이 쉽게 변경할 수 있으며 그 반대의 경우도 마찬가지입니다.
MVVM 적용에서 나오는 세 가지 주요 사항이 있습니다.
- Maintainability
- Testability
- Extensibility
- 어떤 사람들은 단순한 UI의 경우 MVVM이 과잉 일 수 있다고 생각합니다.
- 마찬가지로 더 큰 경우에는 ViewModel을 디자인하기가 어려울 수 있습니다.
- 복잡한 데이터 바인딩이있는 경우 디버깅이 약간 어려울 수 있습니다.
일반적으로 모델은 가장 이해하기 쉬운 모델입니다. 애플리케이션에서보기를 지원하는 것은 클라이언트 측 데이터 모델입니다.
메모리에 데이터를 포함하기 위해 속성과 일부 변수가있는 개체로 구성됩니다.
이러한 속성 중 일부는 다른 모델 개체에 대한 참조를 가질 수 있으며 전체적으로 모델 개체 인 개체 그래프를 생성 할 수 있습니다.
모델 개체는 WPF에서 데이터 바인딩을 의미하는 속성 변경 알림을 발생시켜야합니다.
마지막 책임은 선택 사항 인 유효성 검사이지만 INotifyDataErrorInfo / IDataErrorInfo와 같은 인터페이스를 통해 WPF 데이터 바인딩 유효성 검사 기능을 사용하여 모델 개체에 유효성 검사 정보를 포함 할 수 있습니다.
뷰의 주요 목적과 책임은 사용자가 화면에서 보는 구조를 정의하는 것입니다. 구조에는 정적 및 동적 부품이 포함됩니다.
정적 부분은 뷰가 구성되는 컨트롤의 레이아웃과 컨트롤을 정의하는 XAML 계층 구조입니다.
동적 부분은보기의 일부로 정의 된 애니메이션 또는 상태 변경과 같습니다.
MVVM의 주요 목표는 뷰 뒤에 코드가 없어야한다는 것입니다.
보기에서 최소한 생성자와 구성 요소를 초기화하는 호출이 필요합니다.
이벤트 처리, 작업 및 데이터 조작 논리 코드는 View의 코드 뒤에 있어서는 안됩니다.
UI 요소에 대한 참조를 가져야하는 코드 뒤의 코드에 포함되어야하는 다른 종류의 코드도 있습니다. 본질적으로 뷰 코드입니다.
ViewModel은 MVVM 애플리케이션의 주요 포인트입니다. ViewModel의 주요 책임은 뷰에 데이터를 제공하여 뷰가 해당 데이터를 화면에 표시 할 수 있도록하는 것입니다.
또한 사용자가 데이터와 상호 작용하고 데이터를 변경할 수 있습니다.
ViewModel의 또 다른 주요 책임은 뷰에 대한 상호 작용 논리를 캡슐화하는 것이지만 이것이 응용 프로그램의 모든 논리가 ViewModel로 이동해야한다는 의미는 아닙니다.
사용자 또는 뷰의 변경 사항에 따라 올바른 일이 발생하도록 호출의 적절한 순서를 처리 할 수 있어야합니다.
ViewModel은 다른보기로 이동할시기를 결정하는 것과 같은 탐색 논리도 관리해야합니다.
뷰를 구성하는 방법에는 두 가지가 있습니다. 그중 하나를 사용할 수 있습니다.
- XAML에서 첫 번째 생성보기
- 코드 숨김에서 첫 번째 구성보기
한 가지 방법은 다음 코드와 같이 DataContext 속성에 대한 setter에서 ViewModel을 중첩 요소로 추가하는 것입니다.
<UserControl.DataContext>
<viewModel:StudentViewModel/>
</UserControl.DataContext>
또 다른 방법은 인스턴스와 함께 DataContext 속성을 설정하여 뷰 뒤에있는 코드에서 뷰 모델을 직접 구성하여 뷰 우선 생성을 수행 할 수 있다는 것입니다.
일반적으로 DataContext 속성은 뷰의 생성자 메서드에서 설정되지만 뷰의 Load 이벤트가 발생할 때까지 생성을 연기 할 수도 있습니다.
using System.Windows.Controls;
namespace MVVMDemo.Views {
/// <summary>
/// Interaction logic for StudentView.xaml
/// </summary>
public partial class StudentView : UserControl {
public StudentView() {
InitializeComponent();
this.DataContext = new MVVMDemo.ViewModel.StudentViewModel();
}
}
}
XAML 대신 코드 숨김에서 ViewModel을 생성하는 주된 이유는보기 모델 생성자가 매개 변수를 사용하지만 XAML 구문 분석은 기본 생성자에 정의 된 경우에만 요소를 생성 할 수 있기 때문입니다.
ViewModelLocator는 ViewModel을 View에 연결하는 프로세스를 자동화하는 View First 구성을 수행하는 표준적이고 일관 적이며 선언적이며 느슨하게 결합 된 방법을 제공합니다. 다음은 ViewModelLocator의 고급 프로세스입니다.
- 어떤 뷰 유형이 생성되고 있는지 파악합니다.
- 특정보기 유형에 대한 ViewModel을 식별합니다.
- 해당 ViewModel을 생성합니다.
- Views DataContext를 ViewModel로 설정합니다.
데이터 바인딩은 MVVM을 MVC 및 MVP와 같은 다른 UI 분리 패턴과 차별화하는 핵심 기능입니다.
데이터 바인딩은 OneWay 또는 TwoWay로 View와 ViewModel간에 데이터를주고받을 수 있습니다.
암시 적 데이터 템플릿은 데이터 바인딩을 사용하는 요소에 대해 현재 리소스 사전에서 적절한 템플릿을 자동으로 선택할 수 있습니다. 데이터 바인딩에 의해 렌더링되는 데이터 개체의 유형에 따라이를 수행합니다. 먼저 데이터 개체에 바인딩되는 요소가 있어야합니다.
명령 패턴에는 두 가지 주요 액터, 호출자와 수신자가 있습니다.
Invoker
Invoker는 명령 적 논리를 실행할 수있는 코드 조각입니다. 일반적으로 사용자가 UI 프레임 워크의 컨텍스트에서 상호 작용하는 UI 요소입니다. 그러나 응용 프로그램의 다른 곳에서 논리 코드의 또 다른 청크 일 수 있습니다.
Receiver
Receiver는 호출자가 실행될 때 실행되도록 의도 된 논리입니다. MVVM의 컨텍스트에서 수신자는 일반적으로 호출해야하는 ViewModel의 메서드입니다.
호출자와 수신자 사이에는 호출자와 수신자가 서로에 대해 명시 적으로 알 수 없도록 차단 계층이 있습니다. 이것은 일반적으로 호출자에게 노출 된 인터페이스 추상화로 표현되며 해당 인터페이스의 구체적인 구현은 수신자를 호출 할 수 있습니다.
아니요, 콘텐츠 청크가 화면에 무언가를 렌더링하는 구조 만 제공하고 해당 콘텐츠에 대한 사용자의 입력이나 조작을 지원하지 않는 경우입니다. 별도의 ViewModel이 필요하지 않을 수 있지만 부모 ViewModel에 의해 노출 된 속성을 기반으로 렌더링되는 청크 XAML 일 수 있습니다.
애플리케이션이 최종 사용자의 데이터 입력을 받아들이 기 시작하면 해당 입력의 유효성을 검사해야합니다. 전체 요구 사항을 준수하는지 확인합니다.
WPF 데이터 바인딩에서 지원하는 유효성 검사를 표현하는 다음과 같은 방법을 사용할 수 있습니다.
- 속성에 예외 발생이 설정되었습니다.
- IDataErrorInfo 인터페이스 구현.
- INotifyDataErrorInfo 구현.
- WPF 유효성 검사 규칙을 사용합니다.
IoC (Inversion of Control) 및 종속성 주입은 밀접하게 관련된 두 가지 디자인 패턴이며 컨테이너는 기본적으로 이러한 두 패턴을 모두 수행하는 인프라 코드 청크입니다. IoC 패턴은 생성에 대한 책임을 위임하는 것이고 의존성 주입 패턴은 이미 생성 된 객체에 대한 의존성을 제공하는 것입니다.
이벤트는 상태 변경에 반응하여 알림을 위해 등록 된 모든 엔드 포인트에 알리는 프로그래밍 구조입니다. 주로 이벤트는 마우스와 키보드를 통해 사용자 입력을 알리는 데 사용되지만 그 유용성은 이에 국한되지 않습니다. 상태 변경이 감지 될 때마다, 아마도 객체가로드되거나 초기화 될 때 이벤트가 발생하여 관심있는 제 3 자에게 경고 할 수 있습니다.