大道至简 | MVC+delegate,架构的方式,简单点

百家 作者:iOS开发 2018-05-11 11:33:04

点击上方“iOS开发”,选择“置顶公众号”

关键时刻,第一时间送达!


写在前面


MVC架构模式和delegate设计模式是我们最熟悉的架构模式和设计模式,正确运用它们可以轻而易举的将复杂页面打造得简洁明了、层次分明,下面就分享下我的一点心得。


关于MVC


起初,我想当然的认为MVC架构就是三个文件夹(model,view,controller),后来我读了唐巧的《被误解的MVC》,我才知道,MVC不仅可以有三个文件夹,还可以有四个文件夹、五个文件夹。。。


其实说白了就是将业务逻辑细分然后从controller中抽离出来封装成单独的类。比如说数据请求,你可以单独建个类用于此页面的数据请求;还比如说数据缓存,你也可以单独建个类而不是直接写在controller中。


把这些繁琐的业务逻辑代码分离出来,不仅controller更轻了,修改和维护也容易多了。


当然,MVC并不是文件夹而是思想,既然是思想,那就只有在学习和交流中才能碰撞出火花。


MVC+delegate在实际开发中的运用


一,拿到UI图,我会将它拆分成几个模块:


原图


拆分后


二,将各个模块封装成自定义view:



三,模块传值到controller一律用delegate:


  • 以主分类栏为例:


主分类栏.h文件


#import @class CWFCategoryListMainCatView;

@protocol
CWFCategoryListMainCatViewDelegate // 主分类栏cell点击

- (void)mainCatView:(CWFCategoryListMainCatView *)mainCatView clickedItemAtIndex:(NSInteger)index;

@end


@interface CWFCategoryListMainCatView : UIView


@property (nonatomic, strong) NSMutableArray *dataArray;
@property (nonatomic, weak) id  delegate;

@end


传值到controller:


- (void)mainCatView:(CWFCategoryListMainCatView *)mainCatView clickedItemAtIndex:(NSInteger)index {
   // 要执行的代码
   ....
}


四,整个controller的代码组织:



优点


  1. 每个模块都对应一个delegate,你的任何操作都可以快速定位到相应代码。

  2. 低耦合,模块与模块之间无牵连。

  3. 代码组织非常清晰,任何人来接手都可以快速上手。实际上,可维护性永远是我们开发的重中之重,不管你用何种架构模式或设计模式,如果只是提高了效率却降低了代码可读性,那么,你就是在挖坑。


注意点


  1. 代理方法的命名务必规范,正确命名的代理方法可以很直观的告诉了我们“模块&操作”。


  2. 不要看我这里用的delegate传值就想当然的认为我所有传值都用的delegate,实际上,貌似我也只有模块传值到controller的时候是用的delegate。对于嵌套的view传值到controller,比如view1->view2->controller,我一般会先用block传值到view2,再通过delegate传值到controller。


总结


曾经我也在controller中一口气写个一两千行代码,自己看自己的代码有时都觉得头痛。


第一次进步是学会将controller中搭建UI的代码抽离出来转化成自定义view,也就是模块,从此以后,修改view的代码轻松多了;


第二次进步是学会正确的写delegate,从此以后,定位操作到代码变得迅速,controller的代码组织也看起有模有样了;


第三次进步是学会细分业务逻辑并从controller中抽离出来,从此以后,控制器不再臃肿,维护,so easy。至此,终于对自己的代码满意了。


从公司的角度来讲,公司需要的是好的产品,而好的产品一定是好维护的。


每只小菜鸟都终将成为一只更大的菜鸟。


嘤嘤嘤~


  • 作者:无夜之星辰

  • 链接:https://www.jianshu.com/p/37fe8ce3ca78

  • iOS开发整理发布,转载请联系作者授权

【点击成为源码大神】

关注公众号:拾黑(shiheibook)了解更多

[广告]赞助链接:

四季很好,只要有你,文娱排行榜:https://www.yaopaiming.com/
让资讯触达的更精准有趣:https://www.0xu.cn/

公众号 关注网络尖刀微信公众号
随时掌握互联网精彩
赞助链接