再窥iOS架构模式
· 阅读需 4 分钟
我们为什么要在架构上费心思?
移动开发人员会在以下三个层面上评估一个架构的好坏:
- 各个功能分区的职责分配是否均衡
- 是否具有易测试性
- 是否易于使用和维护
职责分配的均衡性 | 易测试性 | 易用性 | |
---|---|---|---|
紧耦合MVC | ❌ | ❌ | ✅ |
Cocoa MVC | ❌ V和C是耦合的 | ❌ | ✅⭐ |
MVP | ✅ 独立的视图生命周期 | ✅ | 一般:代码较多 |
MVVM | ✅ | 一般:视图(View)存在对UIKit的依赖 | 一般 |
VIPER | ✅⭐️ | ✅⭐️ | ❌ |
紧耦合MVC
举一个例子,在一个多页面的网页Web应用程序中,当你点击一个链接导航至其他页面的时候,该页面就会被全部重新加载。该架构的问题在于视图(View)与控制器(Controller)和模型(Model)是紧密耦合的。
Cocoa MVC
Cocoa MVC 是苹果公司建议iOS开发者使用的架构。理论上来说,该架构可以通过控制器(Controller)将模型(Model)与视图(View)剥离开。
然而,在实际操作过程中,Cocoa MVC 鼓励大规模视图控制器的使用,最终使得视图控制器完成所有操作。
尽管测试这样的耦合大规模视图控制器是十分困难的,然而在开发速度方面,Cocoa MVC是现有的这些选择里面表现最好的。
MVP
在MVP中,Presenter与视图控制器(view controller)的生命周期没有任何关系,视图可以很轻易地被取代。我们可以认为UIViewController实际上就是视图(View)。