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



推荐阅读
  • HTML前端开发:UINavigationController与页面间数据传递详解
    本文详细介绍了如何在HTML前端开发中利用UINavigationController进行页面管理和数据传递,适合初学者和有一定基础的开发者学习。 ... [详细]
  • 本文探讨了如何通过优化 DOM 操作来提升 JavaScript 的性能,包括使用 `createElement` 函数、动画元素、理解重绘事件及处理鼠标滚动事件等关键主题。 ... [详细]
  • 理解浏览器历史记录(2)hashchange、pushState
    阅读目录1.hashchange2.pushState本文也是一篇基础文章。继上文之后,本打算去研究pushState,偶然在一些信息中发现了锚点变 ... [详细]
  • JavaScript 实现图片文件转Base64编码的方法
    本文详细介绍了如何使用JavaScript将用户通过文件输入控件选择的图片文件转换为Base64编码字符串,适用于Web前端开发中图片上传前的预处理。 ... [详细]
  • Hanks博士是一位著名的生物技术专家,他的儿子Hankson对数学有着浓厚的兴趣。最近,Hankson遇到了一个有趣的数学问题,涉及求解特定条件下的正整数x,而不使用传统的辗转相除法。 ... [详细]
  • 在1995年,Simon Plouffe 发现了一种特殊的求和方法来表示某些常数。两年后,Bailey 和 Borwein 在他们的论文中发表了这一发现,这种方法被命名为 Bailey-Borwein-Plouffe (BBP) 公式。该问题要求计算圆周率 π 的第 n 个十六进制数字。 ... [详细]
  • 长期从事ABAP开发工作的专业人士,在面对行业新趋势时,往往需要重新审视自己的发展方向。本文探讨了几位资深专家对ABAP未来走向的看法,以及开发者应如何调整技能以适应新的技术环境。 ... [详细]
  • 近期尝试从www.hub.sciverse.com网站通过编程手段获取数据时遇到问题,起初尝试使用WebBrowser控件进行数据抓取,但发现使用GET方法翻页时,返回的HTML代码始终相同。进一步探究后了解到,该网站的数据是通过Ajax异步加载的,可通过HTTP查看详细的JSON响应。 ... [详细]
  • 问题场景用Java进行web开发过程当中,当遇到很多很多个字段的实体时,最苦恼的莫过于编辑字段的查看和修改界面,发现2个页面存在很多重复信息,能不能写一遍?有没有轮子用都不如自己造。解决方式笔者根据自 ... [详细]
  • 解决JavaScript中法语字符排序问题
    在开发一个使用JavaScript、HTML和CSS的Web应用时,遇到从SQLite数据库中提取的法语词汇排序不正确的问题,特别是带重音符号的字母未按预期排序。 ... [详细]
  • 本文探讨了如何通过Service Locator模式来简化和优化在B/S架构中的服务命名访问,特别是对于需要频繁访问的服务,如JNDI和XMLNS。该模式通过缓存机制减少了重复查找的成本,并提供了对多种服务的统一访问接口。 ... [详细]
  • Jupyter Notebook多语言环境搭建指南
    本文详细介绍了如何在Linux环境下为Jupyter Notebook配置Python、Python3、R及Go四种编程语言的环境,包括必要的软件安装和配置步骤。 ... [详细]
  • 小编给大家分享一下Vue3中如何提高开发效率,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获, ... [详细]
  • protobuf 使用心得:解析与编码陷阱
    本文记录了一次在广告系统中使用protobuf进行数据交换时遇到的问题及其解决过程。通过这次经历,我们将探讨protobuf的特性和编码机制,帮助开发者避免类似的陷阱。 ... [详细]
  • 本文介绍了 jQuery 的基本使用方法,包括文档就绪函数和常用的鼠标事件处理,以及各种选择器的详细说明。 ... [详细]
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社区 版权所有