MVVM和MVVMLight框架介绍及在项目中的使用详解

作者:Brand 时间:2021-07-29 06:59:10 

一、MVVM 和 MVVMLight介绍

MVVM是Model-View-ViewModel的简写。类似于目前比较流行的MVC、MVP设计模式,主要目的是为了分离视图(View)和模型(Model)的耦合。

它是一种极度优秀的设计模式,但并非框架级别的东西,由MVP(Model-View-Presenter)模式与WPF结合的应用方式时发展演变过来的一种新型架构。

立足于原有MVP框架并且把WPF的新特性糅合进去,以应对PC端开发日益复杂的需求变化。

结构如图所示:

MVVM和MVVMLight框架介绍及在项目中的使用详解

相对于之前把逻辑结构写在Code Behind 里面的方式,MVVM几乎完全解耦了视图和逻辑业务的关系,通过数据绑定和命令来处理UI属性

及事件驱动。同理,ViewModel的视图交互业务逻辑处理导致的属性变更也会通知到View前端,让View前端实时更新。Model中存放数据模型和数据逻辑、业务逻辑。

其实我个人认为,数据和业务交互这一层还是应该另外独立,Model中完全就是实体模型,这样更清晰。

这种类型的双向绑定非常优秀,View的变动,会自动反应到ViewModel上,反之亦然。目前JS前端框架AngularJS也是采用这种设计模式。

MVVM模式和MVC模式一样,主要目的是分离视图(View)和模型(Model),有几大优点

1. 低耦合:视图(View)可以独立于Model变化和修改,一个ViewModel可以绑定到不同的View上,当View变化的时候Model可以不变,当Model变化的时候View也可以不变。

2. 可重用性:可以把一些视图逻辑放在一个ViewModel里面,让很多View重用这段视图逻辑。

3. 独立开发:开发人员可以专注于业务逻辑和数据的开发(ViewModel),设计人员可以专注于页面设计,使用Expression Blend可以很容易设计界面并生成xml代码。

4. 可测试:界面素来是比较难于测试的,而现在测试可以针对ViewModel来写。

希望对MVVM有更进一步了解的同学可以看看这篇文章:https://www.codeproject.com/kb/wpf/wpfmvvmquickstart.aspx,

作者从MVVM的模式介绍到数据绑定、消息通知、命令等几个主要方面都有详细的说明。

如果你目前正在进行微软的 WPF 、Windows Phone、Windows 8、SilverLight相关项目的开发,我先很有必要了解一下MVVM Light框架。

它轻量(相对于Prism),专注(仅负责MVVM架构模式的实现,没有其他多余的组件),高效(使用简易,省时减力),能够帮助你更好的开发你的应用。

MVVMLight的作者Laurent Bugnion 是个微软MVP,这个是MVVMLight的官网:http://www.mvvmlight.net/,上面有详细的介绍和视频文档。

有趣的是,MVVMLight的产品Logo是一根羽毛,寓意了我们上面提到的优点:轻量、专业、高效,不知道作者是不是这个意思。

MVVM和MVVMLight框架介绍及在项目中的使用详解

二、如何在你的WPF应用中使用MVMLight

主要使用方式有两种;

一种是去官网上下载MVVMLight Toolkit,安装之后,VS模板中会出现MvvmLight项目模板,你可以直接使用该项目模板来创建项目了。

里面会包含默认的ViewModelLocator和MainViewModel,MainViewModel就是你Main视图的ViewModel了,而ViewModelLocator是一个全局的ViewModel加载注册器,这个第二篇会详细说到。

另一种方式就是去NuGet上安装,这无疑是最便捷的事了。在NuGet 工具箱上搜索 MVVM Light,可以看到两个项目,一个是MVVM Light , 一个是 MVVM Light libraries only。

当前版本是5.3,说明MVVM Light的更新速度还是挺快的,Prerelease中还有 V5.4 的 ALAPHA 版本。

Nuget上这两个项目的区别就是MVVM Light除了必要的GalaSoft 组件之外,还会额外添加相关分层文件目录形成简单的MVVMLight成型框架。

MVVM和MVVMLight框架介绍及在项目中的使用详解

如图它会帮你生成ViewModel文件夹,里面包含MainViewModel和ViewModelLocator文件。

MVVM和MVVMLight框架介绍及在项目中的使用详解

至此,一个基于MVVMLight的WPF项目框架基本搭建完成了,下面一篇我们详细说下框架的结构。

来源:https://www.cnblogs.com/wzh2010/p/6285954.html

标签:MVVM,MVVMLight,框架
0
投稿

猜你喜欢

  • java性能优化之编译器版本与平台对应关系

    2023-09-04 18:31:48
  • Spring boot集成Mybatis的方法教程

    2023-11-25 06:20:41
  • IDEA 设置显示内存的使用情况和内存回收的方法

    2023-10-08 15:51:25
  • SpringBoot 如何使用RestTemplate发送Post请求

    2022-03-03 09:35:47
  • Flow转LiveData数据丢失原理详解

    2023-05-20 10:22:25
  • android获取ibeacon列表的方法

    2023-01-18 00:57:54
  • Android 在viewPager中双指缩放图片双击缩放图片单指拖拽图片的实现思路

    2021-12-09 14:04:22
  • java&javascript自定义加密数据传输代码示例

    2021-11-29 02:09:33
  • Java实现的zip工具类完整实例

    2021-06-22 07:16:17
  • 利用HorizontalScrollView实现滑动页面时的缩放效果

    2022-12-09 13:22:32
  • Java图像之自定义角度旋转(实例)

    2023-10-07 21:04:28
  • 使用springboot整合RateLimiter限流过程

    2022-09-12 21:42:48
  • C#数字图像处理之图像缩放的方法

    2023-02-12 11:09:29
  • Android Studio 运行按钮灰色的完美解决方法

    2023-08-16 05:59:42
  • Java通过FTP服务器上传下载文件的方法

    2021-08-15 07:26:39
  • java返回集合为null还是空集合及空集合的三种写法小结

    2021-08-18 05:37:48
  • Java中joda日期格式化工具的使用示例

    2023-03-01 11:49:10
  • java8 Stream list to Map key 重复 value合并到Collectio的操作

    2022-02-01 23:53:58
  • 一文带你了解RabbitMQ消息转换器

    2023-11-15 23:22:28
  • Java这个名字的来历与优势

    2023-03-27 18:28:40
  • asp之家 软件编程 m.aspxhome.com