MVVM的优劣

作者: 这事情急不得 | 来源:发表于2019-04-13 09:33 被阅读62次

MVVM,也就是传说中的Model,ViewModel,View结构。自AngularJS开始大红大紫。

自MVC横空出世以来,对MVC的改进一直都没有停止过,MVC2, MVP, MVVM都号称是对MVC的改进,但其实MVC真的有什么问题要改进吗?MVC本身其实并没有什么缺陷,只不过是针对不同的应用场合,可以对MVC稍作变化,使得程序员的生产率更高些罢了,所以就出来了很多其他的MV*结构。

所有这些结构要解决的根本问题就是怎么把View和Model分开,View只管自己的UI部分,Model只管自己的数据部分,这样无论是改UI还是改数据,都比较轻松。

然而把VIew和Model分开之后,一个棘手的问题就是代码逻辑如何把View和Model再粘合起来,Model改变了要通知View拿新的数据,用户操作View让数据发生改变后代码逻辑要让Model能更新到新数据。于是对于这些逻辑操作的顺序的不同定义,产生了各种的MV*结构。

MVVM的精髓就在于ViewModel这一层,从名字就可以看出它这一层的作用就是用来给View和Model沟通的通道。ViewModel里面用的最核心的技术叫做双向绑定,也就是Model的任何改动,不需要任何的代码逻辑,就能直接反映到View上面,而View上的任何数据更新,不需要任何其他的代码逻辑,也能直接把Model给更新了。不像MVC,还得在Controller里写代码来通知更新,MVVM的更新是全自动的。

双向绑定不得不说是一个伟大的发明。然而,MVVM的全部好处也就仅限于此了。假如,从View到Model并不是仅靠简单的几行绑定代码就能搞定的,比如View的数据要经过复杂的业务逻辑转换后才能在Model上更新,那么这个时候,即便是绑定,也只能绑定一个用来转换的函数而已,所有的代码也必须自己在这个函数里写出来,如此一来MVVM就退化成MVC/MVP了。

可见,MVVM与MVP/MVC之间的距离,也就是一个双向绑定而已。

双向绑定虽然好,但是也有让人捉急的时候。ViewModel虽然名字叫ViewModel,但是却不能很容易的操作View。因为ViewModel的哲学是所有View里要用到的都需要双向绑定,所以对于没有绑定的View的元素,比如你要在View里加个div什么的,你会发现还是只能用JQuery去操作。这就是双向绑定的一个劣势,双向绑定在绑定静态内容上确实威风无比,但是在动态内容上就不太行了。一旦你用了JQuery,那么其实你的ViewModel就已经混杂Controller逻辑了。

MVVM还有个问题就是容易把ViewModel和Model混在一起。反正ViewModel里是绑定Model,何不把Model就写在ViewModel里面呢?这样显然是不利于维护的。

MVVM也容易被滥用,写架构的人把MVVM当成了神一样的存在,任何东西都试图给它搞一个MVVM出来。比如一个页面上可能几十个控件,每个控件他都要搞一个MVVM出来,定义出Model,ViewModel和View的3个文件。如此一来文件的数量一下子就激增了。加个简单的div也要改3个文件。而且当双向绑定绑定的东西太多的时候,性能会有所影响,特别是如果绑定了很多的事件回调,那么事件回调满天飞,很难debug到源头。MVVM这个其实是一个架构模式,而不是一个设计模式。用MVVM可以来做架构的设计,但是把它当成设计模式就是不对了。

这又让我想到了,在前公司培训的时候那个来自O记的项目经理一直在强调的每个method不超过30行。这种死板做法看似code是clean了,但是很容易造成文件数量大爆炸,如果改一个东西需要改很多个相关文件所带来的效率损失大于code clean所带来的效率提升,那实际上是得不偿失的。真正的clean code并不在method的行数。

最后我想说一下Model,但也并不限于MVVM。Model到底应该不应该包含代码逻辑,到底应该不应该把Model做成只有纯粹的数据?Model如果不包含代码逻辑,那么一个简单的类比就是Java的POJO,只有get和set方法。这样的好处是Model异常简单明了。但坏处是对Model操作的所有逻辑都在Controller/ViewModel里面,导致Controller/ViewModel异常臃肿,这也就是所谓的贫血模型。肯定有人会agrue说这样才是最清晰完美的分层。这没错,但是分层并不是OO。Model里面没有任何逻辑操作的话,也就不能qualify为一个OO的object。一个不OO的design,Controller/ViewModel这一层写起来估计是十分痛苦的。如果想要OO,那么Model里应该包含和Model自身相关的操作逻辑,这就是所谓的充血模型。但这样Model就会显的不清晰,和Controller/ViewModel之间的调用接口也没有分层那样清楚了。所以如何design,其实说到底就是个balance的问题。

相关文章

  • MVVM的优劣

    MVVM,也就是传说中的Model,ViewModel,View结构。自AngularJS开始大红大紫。 自MVC...

  • MVC 和 MVVM 的理解

    前言 MVC 和 MVVM 做为常用的两种架构模式,开发的过程中经常被提起,选择 MVC 和 MVVM 没有优劣之...

  • 双向绑定

    实现双向绑定Proxy比defineproperty优劣如何? 关于双向绑定,其实只要涉及到MVVM框架就不得不提...

  • Android-DataBinding分析

    一、DataBinding 的优劣势 1、优势 原生支持MVVM在不改变原有代码构架上,让业务与UI分离 提高开发...

  • DataBinding深入使用(一)

    简介 Android开发中最常见的三种设计模式为mvc、mvp、及mvvm,每种设计模式都各有优劣,这篇文章主要介...

  • 浏览器渲染机制

    为深入了解vue mvvm模式的优劣 现从浏览器渲染机制开始从头梳理 首先,浏览器将域名通过网络通信从服务器上拿到...

  • 值得学习的技术文章(持续添加)

    1. MVVM 学习资料 MVVM奇葩说 面向协议的 MVVM 架构介绍 MVVM With ReactiveCo...

  • vue入门

    MVVM的介绍 vue的设计思想是基于MVVM实现的,那么什么是MVVM呢?简单介绍: 组成 MVVM ===> ...

  • MVVM的数据持久化(一)——ROOM的集成

    MVVM框架的搭建(一)——背景MVVM框架的搭建(二)——项目搭建MVVM框架的搭建(三)——网络请求MVVM的...

  • MVVM的数据持久化(二)——ROOM的使用

    MVVM框架的搭建(一)——背景MVVM框架的搭建(二)——项目搭建MVVM框架的搭建(三)——网络请求MVVM的...

网友评论

    本文标题:MVVM的优劣

    本文链接:https://www.haomeiwen.com/subject/qvsiiqtx.html