Model-View-ViewModelModel-View-ViewModel — шаблон проєктування, що застосовується під час проєктування архітектури застосунків (додатків). Публічно вперше був представлений Джоном Госсманом (John Gossman) у 2005 році як модифікація шаблону Presentation Model. MVVM орієнтований на такі сучасні платформи розробки, як Windows Presentation Foundation та Silverlight від компанії Microsoft. MVVM полегшує відокремлення розробки графічного інтерфейсу від розробки бізнес логіки (бек-енд логіки), відомої як модель (можна також сказати, що це відокремлення представлення від моделі). Модель представлення є частиною, яка відповідає за перетворення даних для їх подальшої підтримки і використання. З цієї точки зору, модель представлення більше схожа на модель, ніж на представлення і оброблює більшість, якщо не всю, логіку відображення даних. Модель представлення може також реалізовувати патерн медіатор, організовуючи доступ до бек-енд логіки навколо множини правил використання, які підтримуються представленням. ПризначенняMVVM використовується для відокремлення моделі та її відображення. Необхідністю цього є надання можливості змінювати їх незалежно одну від одної. Наприклад, розробник працює над логікою роботи з даними, а дизайнер — з користувацьким інтерфейсом. MVVM була створена з метою поділу праці дизайнера і програміста, що є неможливим, коли Java-розробник намагається побудувати GUI в Swing або розробник на Visual C++ намагається створити користувальницький інтерфейс в MFC. Розробники кмітливі і мають безліч навичок, але створення зручних і привабливих інтерфейсів вимагає абсолютно інших талантів, ніж ті, якими вони володіють. Ця робота більше підходить для дизайнерів інтерфейсів. Хороші дизайнери інтерфейсів краще знають, чого бажають користувачі, ніж експерти в області проєктування і написання коду. Зрозуміло, буде краще, якщо дизайнер інтерфейсів створить інтерфейс, а розробник напише код, який реалізує логіку цього інтерфейсу, але технології типу Swing або MFC просто-напросто не дозволяють чинити таким чином. Використання[1]
В MVC/MVP зміни у користувацькому інтерфейсі не впливають безпосередньо на модель, а йдуть через Контролер/Presenter. У таких технологіях, як WPF та Silverlight, присутня концепція «зв'язування даних», що дозволяє зв'язувати дані із візуальними елементами в обидві сторони. Архітектура MVVM вирішує цю проблему ясним поділом відповідальності:
Архітектура MVVM використовується в тому чи іншому вигляді усіма сучасними технологіями, наприклад Microsoft WPF і Silverlight, Oracle JavaFX, Adobe Flex, AJAX. ОписШаблон MVVM ділиться на три частини:
РеалізаціяПриклад реалізації шаблону у Windows Presentation Foundation. Оголосимо модель, що містить логіку застосунку, не залежну від представлення. public class OrderDto
{
public string Name { get; set; }
}
public interface IOrdersModel
{
OrderDto[] LoadOrders();
}
public class OrdersModel : IOrdersModel
{
public OrderDto[] LoadOrders()
{
return new OrderDto[]
{
new OrderDto(){ Name = "Item1" },
new OrderDto(){ Name = "Item2" },
};
}
}
Додамо модель вигляду — компонент, що зв'язує логіку застосунку (модель) із виглядом. public class OrderViewModel
{
private readonly IOrdersModel ordersModel;
// колекція, що вміє сповіщати про зміну своїх даних
public ObservableCollection<string> Orders { get; set; } = new ObservableCollection<string>();
public OrderViewModel(IOrdersModel ordersModel)
{
this.ordersModel = ordersModel;
}
// метод-обробник, виконується при взаємодії користувача із виглядом
public ICommand LoadOrders => new RelayCommand((object sender) =>
{
// керування моделю
var orders = ordersModel.LoadOrders();
// оновлення колекції до якої прив'язаний вигляд
foreach (var order in orders)
{
Orders.Add(order.Name);
}
});
}
Та додамо вигляд — для взаємодії із користувачем. <Window>
<Button Command="{Binding LoadOrders}" />
// зв'язування даних
<ListBox ItemsSource="{Binding Orders}"/>
</Window>
Примітки
|