热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

wpf+mvvm代码组织结构及实现方式

本文介绍了wpf+mvvm代码组织结构的由来和实现方式。作者回顾了自己大学时期接触wpf开发和mvvm模式的经历,认为mvvm模式使得开发更加专注于业务且高效。与此同时,作者指出mvvm模式相较于mvc模式的优势。文章还提到了当没有mvvm时处理数据和UI交互的例子,以及前后端分离和组件化的概念。作者希望能够只关注原始数据结构,将数据交给UI自行改变,从而解放劳动力,避免加班。

还记得我上大学时候有幸接触wpf开发,也是那时候我开始接触到了mvvm模式,心里一阵欣喜,心想这个模式使得我们可以更加的专注于业务并且更加高效的完成业务代码编写,而不是还要考虑其他跟业务配套不相关的代码,那个时候还是流行mvc的开发模式,不过在我心目中mvvm是吊打mvc的存在。同时代web前端还是估计还是大量用jquery,没什么前后端分离的概念。

举一个当没有mvvm的时候的处理数据跟ui交互的例子,先设置数据

d9e89079bfe4158d49b5a721fe779b64.png

设置ui,这部分如果你做过pc开发或者移动开发就知道一般都是编辑器拖动控件完成的,也相当于与现在前端里提到的组件化

4e93d26d8ea62c52581c867d562ff223.png

接下来写相关的业务

767562bb36de74f436fdcd9977b04662.png

我们现在使用setTimeOut来模拟数据改变

23b77ecd0607f9637c71cf8f52c58183.png

一个非常简单的业务,这里边我们花费了大量的劳动力去写了原始数据改变了给ui重新赋值,ui如果能改变数据,当ui触发数据改变时候,我们也要同样的去改变原始数据。写了很多与业务无关的代码。能不能我只管写原始数据的结构,然后撒手直接丢给ui,你们改变数据你们自己改我不管,如果能实现真的是解放了大量的劳动力,我们可以不用加班,我们可以花更多时间去过happy time等等。。。。

就在这个时候聪明的程序员去开发了一套mvvm机制,使得我们可以免除大量的劳动力去做真正该做的事,那么mvvm是怎么实现的呢,我们现在手动实现自己的mvvm。

先理一下思路,当原始数据变化的要去通知ui,那么这个突破口就是原始数据我们先把数据加工吧。

现实现每个对象当他子数据改变的时候去通知,那么动手实现。

9d0170fd733383e1bf4157e133113b45.png

这一步还算简单,我们首先内部定了新的bindingObj,给这个bindingObj浅拷贝原始obj,然后给原始obj设定set跟get,set的时候给bindingObj设定值然后去通知,get时读取bindingObj的数据。

这还不够我们继续完善,我们发现代码里handleChange时候调用callback的接口,我们现在去写外部可以传入callback的地方,跟强制触发change地方。

7300ac4116628f345065b954048cf5bc.png
eadd18cebb54aaa31d141964deb7a173.png

最终代码是这样上面例子中,我们使用了浅拷贝而不是深拷贝,因为我觉得深拷贝耗费性能。

如果有改动的话可以浅拷贝传参或者改完数据调用setChange就可以了,还有就是添加新的字段的时候也要调用setChange就可以了。

接下来我们改写上边ui跟数据交互的例子。

c151b97bff002cfba76b853cc841eb15.png

你会发现controller这边代码大幅减少,还有setTimeOut里边逻辑简洁不少,不过这时候你会发现这不就是吧controller里边的代码移到view1里边了吗,你骗人哪里少些代码了。

因为是这样现在我们的h1跟input 还没有重新封装他们现在让我们封装一下吧。

0fd48c9bf07099034b4391cd994e886b.png
3905630fbd902401822f2c599da472e8.png
37239390629d72ebdd7947b437923ce9.png

大功告成了。现在我们把每个ui元素都封装成了组件,导致view可以统一处理了,你会说现在是有改动就更新全部数据,当然你如果愿意完全可以在回调里传参数,来更新确定的字段,当然你会发现我没改动一次数据这个view就要更新是不是太费性能了,我们现在改变一下view

9e2ef2e2276bd2e9de3724175a6c65d1.png

改动代码后view在60帧的速度更新数据,当他发现数据变了就会更新view否则就不会更新,现在你是不是终于懂了为什么react或者vue数据改变为什么不会实时更新而是异步更新了吧。



推荐阅读
  • 本文介绍了OC学习笔记中的@property和@synthesize,包括属性的定义和合成的使用方法。通过示例代码详细讲解了@property和@synthesize的作用和用法。 ... [详细]
  • Ihavethefollowingonhtml我在html上有以下内容<html><head><scriptsrc..3003_Tes ... [详细]
  • 本文介绍了在iOS开发中使用UITextField实现字符限制的方法,包括利用代理方法和使用BNTextField-Limit库的实现策略。通过这些方法,开发者可以方便地限制UITextField的字符个数和输入规则。 ... [详细]
  • 本文介绍了在Linux下安装Perl的步骤,并提供了一个简单的Perl程序示例。同时,还展示了运行该程序的结果。 ... [详细]
  • 后台获取视图对应的字符串
    1.帮助类后台获取视图对应的字符串publicclassViewHelper{将View输出为字符串(注:不会执行对应的ac ... [详细]
  • 自动轮播,反转播放的ViewPagerAdapter的使用方法和效果展示
    本文介绍了如何使用自动轮播、反转播放的ViewPagerAdapter,并展示了其效果。该ViewPagerAdapter支持无限循环、触摸暂停、切换缩放等功能。同时提供了使用GIF.gif的示例和github地址。通过LoopFragmentPagerAdapter类的getActualCount、getActualItem和getActualPagerTitle方法可以实现自定义的循环效果和标题展示。 ... [详细]
  • 本文介绍了在Vue项目中如何结合Element UI解决连续上传多张图片及图片编辑的问题。作者强调了在编码前要明确需求和所需要的结果,并详细描述了自己的代码实现过程。 ... [详细]
  • 闭包一直是Java社区中争论不断的话题,很多语言都支持闭包这个语言特性,闭包定义了一个依赖于外部环境的自由变量的函数,这个函数能够访问外部环境的变量。本文以JavaScript的一个闭包为例,介绍了闭包的定义和特性。 ... [详细]
  • Go GUIlxn/walk 学习3.菜单栏和工具栏的具体实现
    本文介绍了使用Go语言的GUI库lxn/walk实现菜单栏和工具栏的具体方法,包括消息窗口的产生、文件放置动作响应和提示框的应用。部分代码来自上一篇博客和lxn/walk官方示例。文章提供了学习GUI开发的实际案例和代码示例。 ... [详细]
  • FineReport平台数据分析图表显示部分系列接口的应用场景和实现思路
    本文介绍了FineReport平台数据分析图表显示部分系列接口的应用场景和实现思路。当图表系列较多时,用户希望可以自己设置哪些系列显示,哪些系列不显示。通过调用FR.Chart.WebUtils.getChart("chartID").getChartWithIndex(chartIndex).setSeriesVisible()接口,可以获取需要显示的系列图表对象,并在表单中显示这些系列。本文以决策报表为例,详细介绍了实现方法,并给出了示例。 ... [详细]
  • 预备知识可参考我整理的博客Windows编程之线程:https:www.cnblogs.comZhuSenlinp16662075.htmlWindows编程之线程同步:https ... [详细]
  • 本文介绍了一种处理AJAX操作授权过期的全局方式,以解决Asp.net MVC中Session过期异常的问题。同时还介绍了基于WebImage的图片上传工具类。详细内容请参考链接:https://www.cnblogs.com/starluck/p/8284949.html ... [详细]
  • 如何提高PHP编程技能及推荐高级教程
    本文介绍了如何提高PHP编程技能的方法,推荐了一些高级教程。学习任何一种编程语言都需要长期的坚持和不懈的努力,本文提醒读者要有足够的耐心和时间投入。通过实践操作学习,可以更好地理解和掌握PHP语言的特异性,特别是单引号和双引号的用法。同时,本文也指出了只走马观花看整体而不深入学习的学习方式无法真正掌握这门语言,建议读者要从整体来考虑局部,培养大局观。最后,本文提醒读者完成一个像模像样的网站需要付出更多的努力和实践。 ... [详细]
  • 本文介绍了MVP架构模式及其在国庆技术博客中的应用。MVP架构模式是一种演变自MVC架构的新模式,其中View和Model之间的通信通过Presenter进行。相比MVC架构,MVP架构将交互逻辑放在Presenter内部,而View直接从Model中读取数据而不是通过Controller。本文还探讨了MVP架构在国庆技术博客中的具体应用。 ... [详细]
  • 一、什么是闭包?有什么作用什么是闭包闭包是定义在一个函数内部的函数,它可以访问父级函数的内部变量。当一个闭包被创建时,会关联一个作用域—— ... [详细]
author-avatar
q40796672
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有