热门标签 | 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数据改变为什么不会实时更新而是异步更新了吧。



推荐阅读
  • 本文探讨了2019年前端技术的发展趋势,包括工具化、配置化和泛前端化等方面,并提供了详细的学习路线和职业规划建议。 ... [详细]
  • 深入理解Vue.js:从入门到精通
    本文详细介绍了Vue.js的基础知识、安装方法、核心概念及实战案例,帮助开发者全面掌握这一流行的前端框架。 ... [详细]
  • 本文详细介绍了如何在Kendo UI for jQuery的数据管理组件中,将行标题字段呈现为锚点(即可点击链接),帮助开发人员更高效地实现这一功能。通过具体的代码示例和解释,即使是新手也能轻松掌握。 ... [详细]
  • 前端开发:从底层到顶端的行业现象解析
    在编程领域,鄙视链现象屡见不鲜,从C语言到Java、.NET等,每个技术栈都有其独特地位。然而,前端开发者尽管常处于鄙视链底端,却在市场需求中备受青睐。本文深入探讨这一现象,并分析前端工程师如何在竞争激烈的市场中脱颖而出。 ... [详细]
  • 本文介绍了多个关于JavaScript的书籍资源、实用工具和编程实例,涵盖从入门到进阶的各个阶段,帮助读者全面提升JavaScript编程能力。 ... [详细]
  • 本文将深入探讨如何在不依赖第三方库的情况下,使用 React 处理表单输入和验证。我们将介绍一种高效且灵活的方法,涵盖表单提交、输入验证及错误处理等关键功能。 ... [详细]
  • 在现代Web应用中,当用户滚动到页面底部时,自动加载更多内容的功能变得越来越普遍。这种无刷新加载技术不仅提升了用户体验,还优化了页面性能。本文将探讨如何实现这一功能,并介绍一些实际应用案例。 ... [详细]
  • 本文详细介绍了 org.apache.commons.io.IOCase 类中的 checkCompareTo() 方法,通过多个代码示例展示其在不同场景下的使用方法。 ... [详细]
  • 本文探讨了如何利用jQuery在客户端实现页面跳转,并详细介绍了如何确保页面在浏览器的顶层窗口中打开,而不是局限于当前框架内。 ... [详细]
  • 使用JS、HTML5和C3创建自定义弹出窗口
    本文介绍如何结合JavaScript、HTML5和C3.js来实现一个功能丰富的自定义弹出窗口。通过具体的代码示例,详细讲解了实现过程中的关键步骤和技术要点。 ... [详细]
  • Spring Boot 中静态资源映射详解
    本文深入探讨了 Spring Boot 如何简化 Web 应用中的静态资源管理,包括默认的静态资源映射规则、WebJars 的使用以及静态首页的处理方法。通过本文,您将了解如何高效地管理和引用静态资源。 ... [详细]
  • 本文介绍了一种解决二元可满足性(2-SAT)问题的方法。通过具体实例,详细解释了如何构建模型、应用算法,并提供了编程实现的细节和优化建议。 ... [详细]
  • 本文探讨了如何在日常工作中通过优化效率和深入研究核心技术,将技术和知识转化为实际收益。文章结合个人经验,分享了提高工作效率、掌握高价值技能以及选择合适工作环境的方法,帮助读者更好地实现技术变现。 ... [详细]
  • 本文介绍了Android开发中Intent的基本概念及其在不同Activity之间的数据传递方式,详细展示了如何通过Intent实现Activity间的跳转和数据传输。 ... [详细]
  • 本文探讨了2012年4月期间,淘宝在技术架构上的关键数据和发展历程。涵盖了从早期PHP到Java的转型,以及在分布式计算、存储和网络流量管理方面的创新。 ... [详细]
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社区 版权所有