MVVM模式开发WinForm-ReactiveUI

本文介绍了如何使用MVVM设计模式提升WinForm开发效率,重点讲解了ReactiveUI框架在WinForm中的应用,通过一个简单的示例展示如何创建ViewModel,绑定控件,实现数据双向同步。
摘要由CSDN通过智能技术生成

一、引言

  谈到MVVM设计模式,首先让人想到的是WPF。没错,MVVM的概念是微软在2005年提出的,并首次将其应用到WPF中。最近非常火的Vue.js也是使用了MVVM的设计模式。MVVM设计模式的核心部分是DataBinding机制。顾名思义,其功能就是将ViewModel绑定到View,并且将View控件的变换绑定到ViewModel的双向绑定。MVVM的优点是业务逻辑层不用关注View,只专注对ViewModel的处理,开发效率提升很大。

二、背景

  最近公司在开发一套管理系统的桌面客户端程序,由于各种原因,最终选型使用WinForm进行开发。由于好几年没有再接触过WinForm了,起初一段时间非常的不适应,开发效率极低,不仅要考虑不同分辨率的适应情况(这里稍微吐槽一下:WinForm本身就难以处理不同分辨率的自适应),同时还要处理数据的显示及提交。
  既然要提升开发效率,我们先从设计模式下手。今天要为大家带来的是ReactiveUI。
  ReactiveUI是实现了MVVM模式的框架,它的核心目标是可以在ViewModel中相关属性发生变化时可以可执行相应的命令。ReactiveUI支持Xamarin、WPF、WinForm、Windows Phone、UWP。这里我们选择WinForm对应的版本ReactiveUI.WinForms。

三、示例

  下面为大家带来ReactiveUI.WinForms的一个简单的示例,来一起认识ReactiveUI.WinForms。

####1、创建WinForm项目####
打开vs,我们创建一个WinForm的项目:
创建项目
####2、安装ReactiveUI.WinForms####
项目创建完成后,鼠标右键单击当前项目,选择“管理NuGet程序包”,在打开的窗口中选择“浏览”,并搜索ReactiveUI.WinForms进行安装
NuGet
####3、创建ViewModel####
在项目目录下新建文件夹ViewModel,并在文件夹下新建一个PersonViewModel类,写入如下代码:

using ReactiveUI;

namespace WinformMvvm.ViewModel
{
   
    //ViewModel需要继承自ReactiveObject
    public class PersonViewModel : ReactiveObject
    {
   
        private int _id;
        private string _name;
        private int _age;

        public PersonViewModel()
        {
   
            Id = 1;
            Name = "张三";
            Age 
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值