关于MVC MVP MVVM架构模式的总结

一、MVC

首先关于MVC:MVC是苹果官方推荐的模式结构,MVC即 Model  View Controller,他们之间的关系如下图


mvc下,在我们使用的过程中往往事与愿违,耦合性特别高:比如view和model的强依赖,控制器(controller)类里有繁重的UI、啰嗦的业务逻辑、很长的网络层、难受的代理方法等等,而controller的主要任务只需要建立依赖关系(model 和 UI绑定)。

解决方案:解除view和model 的强依赖,解耦合controller类,下面看MVP

二、MVP

MVP: 面向协议编程,也叫面向接口编程 。 需求推动接口的定义,UI 决定model model又能影响UI。解耦合controller 使得代理方法和数据源方法的实现全写在其他类里面(Present),话不多说,直接上代码:

主控制器类:


以上 解除了view与model的强依赖,与业务逻辑相关的代码对于controller类完全不用关心,controller只是建立依赖关系,各自分工明确,代码简洁明了。

Present类:


present类负责完成由UI层到model层的关联,由model的改变再刷新UI(业务逻辑相关交由Present类处理)

与此同时present类用到的协议代理由专门的协议类服务,协议delegate类如下:


由delegate类可知:功能协议,接口协议全部定义在此类里面,也就是需求功能所需要的接口全在这里定义

总结MVP:

功能需求 填充代理接口 代理的的三部曲 根据需求写接口

适合多人开发,可读性强,结构清晰,根据需求文档,看到代理接口定义的地方就能找到业务逻辑层,很好的定位。(需求驱动接口接口驱动代码)

对于页面复杂嵌套层次比较多传值比较频繁的情况不推荐MVP,推荐Block,因为直接回调就可以不需要函数式调用。


三、MVVM

核心思想:双向绑定

1.逆向:通过block  ,ViewModel调用网络层获取数据来逆向传值给controller以更新UI

以上释例代码在controller类中通过ViewModel的block回调处理刷新UI

2.正向 UI ---> model 响应式触发,UI触发一个信号,通过viewModel接收信号做业务处理。

举例:RAC(UI触发数据变化,viewModel接收到数据变化,再次刷新UI)如下示例代码

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容