• 理解MVC、MVP、MVVM在干什么,进化的原因。


    本文参考 戴嘉华《界面之下:还原真实的MV*模式》。以下是我学习的笔记,和些许个人的思考。

    MV*模式

    MVC

    Smalltalk-80 MVC解释
    • View:管理用户界面的层次。
    • Model:提供操作数据的接口,执行业务逻辑。
    • Controller:View和Model之间的协作。

    用户对View操作后,View将处理的权限移交给Controller。Controller进行应用逻辑(调Model哪个接口、对View数据预处理…),具体的业务逻辑交给Model。当Model变更时通过观察者模式告诉View,View收到消息后向Model请求最新的数据,更新界面。

    优缺点
    • 优点:逻辑分离(应用逻辑、业务逻辑、展示逻辑)、多视图更新(观察者模式)。
    • 缺点:单元测试困难,View无法组件化(高度依赖Model)。
    前端思考:
    1. 前端由于HTTP是单工协议,服务端无法向前端发送消息(websocket除外),只能前端发送请求到后端。
    2. MVC模式有点类似于Vuex。在Vuex中,更改state状态的唯一方法就是提交mutation,即业务逻辑。进行应用逻辑的类似于action,action中提交的是mutation。展示逻辑就类似于Getters,负责将数据归纳整理,提供给页面想要的数据。

    MVP

    解释

    大致与MVC相同,唯一不同的是Controller变成了Presenter。

    用户对View操作后,View将处理的权限移交给Presenter。Presenter进行应用逻辑(调Model哪个接口、对View数据预处理…),具体的业务逻辑交给Model。

    不同的是,当Model变更时通过观察者模式告诉Presenter,Presenter通过View提供的接口告诉View

    优缺点
    • 优点:便于对Presenter单元测试、View可组件化。
    • 缺点:Presenter变得臃肿,不仅有应用逻辑,还有同步逻辑。

    MVVM

    解释

    大致与MVP相同,唯一不同的是将Presenter中的同步逻辑分给了“Binder”。Binder主要是负责View和Model双向绑定。

    用户对View操作后,View将处理的权限移交给View-Model。View-Model进行应用逻辑(调Model哪个接口、对View数据预处理…),具体的业务逻辑交给Model。

    不同的是,当Model变更时,通过Binder自动把数据更新到View上。当用户对View操作时,也会自动更新到Model

    优缺点
    • 优点:解决了大量同步问题,提高代码可维护性。便于测试,由于Binder的存在,Model正确即View正确,减少View同步更新测试。
    • 缺点:建立大量View-Model、数据绑定以指令写在View中不便测试。
  • 相关阅读:
    【图像配准】基于surf算法实现图像配准附Matlab代码
    TBarCode SDK 11.15.1 Crack
    944页40万字智能矿山项目建设整体解决方案(煤矿)2021
    localStorage和sessionStorage用法与区别
    Python中的函数
    Android 13.0 Launcher3定制之双层改单层(去掉抽屉式三)
    【软考】8.2 编译程序基本原理/文法/正规式/有限自动机
    SpringBoot原理
    基于PHP实现的网上留言管理系统的设计
    【Redis】Redis入门教程(介绍 下载安装 Jedis 图形化界面)
  • 原文地址:https://blog.csdn.net/weixin_44173943/article/details/127554109