c# – WPF / Silverlight程序员:MVVM是否过度杀伤?

栏目: 编程语言 · 发布时间: 5年前

内容简介:我对MVVM的看法很复杂.似乎我需要编写如此多的代码来获得最有效的补救措施.我想念事件(命令是如此痛苦),绑定一切导致调试噩梦,我错过了对视图的引用!我只是想知道你对MVVM的感受与背后的普通旧代码.你更喜欢什么和/或你通常使用或推荐使用什么?谢谢

我对MVVM的看法很复杂.似乎我需要编写如此多的代码来获得最有效的补救措施.我想念事件(命令是如此痛苦),绑定一切导致调试噩梦,我错过了对视图的引用!

我只是想知道你对MVVM的感受与背后的普通旧代码.你更喜欢什么和/或你通常使用或推荐使用什么?

谢谢

我绝对是少数人,但我倾向于同意@Shnitzel. MVVM以及与之相辅相成的绑定是很好的想法,但它们很难被当前的MS工具所服务.除了最简单的绑定之外的所有语法都非常难以正确使用,并且由于 WPF

和Silverlight无声地吞下所有错误这一事实变得更加困难. (是的,一些错误出现在调试窗口中,但是没有足够的错误,并且没有足够的细节.)你可以使用hacks来编写调试值转换器,但事实仍然是 工具 集仍然很不成熟. (然后是我的标准投诉,数据绑定不是强类型的,这意味着工具无法为您捕获错误.)

当他们坚持可测试性时我听到了所有人,而且我是自动化测试的忠实粉丝.但至少在目前我们的工具状态下,MVVM的可测试性得到了提升,价格非常高.

考虑一下这种情况:你有一个包含50个表单/页面的大型应用程序,而你刚刚进行了Model和ViewModel的重大重构.在此过程中,您重命名了一堆类和属性等.现在找到XAML中您需要更改的每个位置以反映新的类和属性名称.可测试性如此之高,嗯? IDE不仅不会捕获您的绑定错误,编译器也不会捕获它们,最重要的是,应用程序甚至不会在运行时抛出错误.您必须让测试人员在整个应用程序中运行,并确保所有绑定仍在执行您希望他们执行的操作. Ugggh.丑陋而痛苦.至少当我以老式的方式做事时,编译器会告诉我什么时候拼写错误的东西.

回到我的洞穴,以避免吊索和箭头迅速前进…

[编辑12/10/2010 – MS最近宣布SL5将具备 debug data bindings 的能力,包括能够设置断点的能力,因此您可以看到正在发生的事情.这是朝着正确方向迈出的一大步.它仍然没有解决我认为的基本问题,数据绑定没有编译时类型检查,但它提高了工具集的实用性.

翻译自:https://stackoverflow.com/questions/3154171/wpf-silverlight-programmers-is-mvvm-overkill


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

总开关

总开关

[美] 吴修铭 / 顾佳 / 中信出版社 / 2011-8 / 49.00元

当收音机经历从真空管收音机到半导体收音机,再到电晶体收音机的发展升级时,人们觉得自己的资讯来源美满得无可复加了。当约翰.洛吉.贝尔德发明了电视以后,在很长一段时间内,人们都认为电视就是他们所拥有的﹑也是所愿意拥有的最好的资讯媒介。 时至今日,互联网的震撼不亚于以往任何媒介,它给我们带来了最大的信息量,最便捷的自我表达,最迅速的沟通。互联网似乎比以往任何媒介都具有优越性。在互联网成为这个时代主......一起来看看 《总开关》 这本书的介绍吧!

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换

正则表达式在线测试
正则表达式在线测试

正则表达式在线测试