110 likes | 322 Views
Mô hình Model-View- ViewModel. Nhóm H4: Lady Lên Miss Long Thím Quý Mr. Hải. 1 - Why?. Tăng tính hiệu quả trong sự tương tác giữa designer và developer. Tăng khả năng sử dụng lại các component. Thay đổi giao diện chương trình mà không cần thiết phải viết lại code quá nhiều.
E N D
MôhìnhModel-View-ViewModel Nhóm H4:Lady Lên Miss Long ThímQuý Mr. Hải
1 - Why? • Tăngtínhhiệuquảtrongsựtươngtácgiữa designer và developer. • Tăngkhảnăngsửdụnglạicác component. • Thayđổigiaodiệnchươngtrìnhmàkhôngcầnthiếtphảiviếtlại code quánhiều.
Wrong thinking: • MVVM chỉthíchhợpvớicác project cógiaodiệnphứctạp. • MVVM sẽlàmphình to kíchthướccũngnhư chi phíđốivớicácứngdụngnhỏ. • MVVM khôngcânbằng.
2.1 - Model • Model làcácđốitượnggiúptruyxuấtvàthaotáctrêndữliệuthựcsự. • Đơnvịcủa Model chínhlà Class. • VD: class Customer dùngđểlưutrữcácthông tin vềkháchhàng.
2.2 - ViewModel • ViewModellàlớptrunggiangiữa View và Model. ViewModelcóthểđượcxemlàthànhphầnthaythếcho Controller trongmôhình MVC. Nóchứacácmãlệnhcầnthiếtđểthựchiện data binding, command. • ViewModelkhôngmôtảgiaodiệnsẽtrôngnhưthếnào. Nóchỉmôtảcáchmà View hoạtđộngvàthông tin nàosẽđượccungcấpchongườidùng.
2.3 – View • View là phần giao diện của ứng dụng để hiển thị dữ liệu và nhận tương tác của người dùng. • Mộtđiểmkhácbiệt so vớimôhình MVC, là nó có khả năng thực hiện các hành vi và phản hồi lại người dùng thông qua tính năng binding, command.
Sựkếtnốicácthànhphầntrong MVVM. • Bước 1: Tạomẫuchophần View vàgiữchocác View class táchbiệtkhỏiViewModel. • Bước 2: Cáctínhnăngcủa View đượcđịnhnghĩatrongViewModel. • Bước 3: Mỗi element nằmtrong View đềuđượckếtnốitớicác Properties trongViewModelbằng data binding. • Bước 4: ViewModelsẽlấydữliệutừ Model.
Một điểm cần lưu ý là trong mô hình MVVM, các tầng bên dưới sẽ không biết được các thông tin gì về tầng bên trên nó. Như hình minh họa dưới đây:
Comparing the MVC and MVVM • MVC và MVVM hướngtớinhữngloạiứngdụngkhácnhauhoàntoàn. • MVC for web application. • MVVM for desktop application. • Model: bahave the same way in either pattern • View • In MVC only display data and perform basic client side UI duties usually with JavaScript. • In MVVM have a rich databinding and validation framework.