前言:
在之前的文章中,我有介绍过.a和 .framework 的封装,算是为你的组件模块打个基础吧。当你将你的功能块封装后使用起来是不是很方便呢。那么在开发过程中,你是否有遇到过这样的情况:不论是方法的调用、数据的传参,相同的方法或者相同的参数块在多处调用,而给你的项目带来了过多的冗余。那么你是否想过如何减少你项目的耦合问题呢?
举个简单的例子吧,比如:你有一个对象,这个对象你需在多个控制器或者view中调用,最常见到的就是地图的定位了吧。那么你之前一定有使用过单例,这个就是一个很好的解决方法。那么控制器呢,相同问题当你的控制器需要在整个项目中作为一个“单例”呢?
在开发过程中,model的概念大家一定很熟悉,一个参数携带者-对象。如果你对你的项目内存有极高的强迫症的话,你也许像我一样这么做过:平时的项目中,请求的数据量级并不大,使你觉得没有必要去做一个model,而是直接在你的控制器中,对取得的数据进行了处理。(其实,也和习惯有关系吧,哈哈。)那么,当数据量大到你头疼的时候,model就是必不可少的了,常用mjExcetion的人应该会有体会。model的使用,每个开发人员都再熟悉不过了,可是你有仔细想过它吗?你是否在MVC的模式中,从未走出过呢?你的首页MVC中的model,有没有想过也放到其它的地方去呢?不错,你首页的modle它只是一个数据携带者,一个object而已。那么,不论你将它导入到哪里,当它携带了你需要的参数时,它就是你需要的对象。
讲到这里,我觉得可以开始今天的正文了:组件模块化。关于iOS模块化开发的文章有很多,大概有3个方案:
- Protocol注册方案
- URL注册方案
- Target-Action runtime调用方案
对于1和2中的方案,大家可以自己去查查吧。我也是看了他人的文章的,自觉还不够拿来说的。可以给大家推荐一篇吧,附带demo的感觉不错。(https://www.jianshu.com/p/2cb4cc8d216e)
至于第3个方案,倒是恰好有在项目中接触到,将个人的一些经验和理解讲出来吧。即作为个人的笔记,也供大家查看。
本文主要以CTMediator来讲解。
一:模块化开发理解
1.作用:
如果你的项目中有一个首页控制器HomeVC,当你在一个子控制器(例如,订单详情控制器)中,需要调用它时,通常的做法是直接将HomeVC import进来,然后调用。可是当我们的项目中有大量的HomeVC导入时,耦合太高。那么有什么方法可以简洁化呢?CTMediator。
2.CTMediator可以看作是一个target+action的对象,将你要处理的对象打标签、加动作,然然后通过Runtime处理,来达到降低耦合的目的。如果你将它看作一个model,那么它就是一个打了tag加了action的参数携带者,而它的处理过程中的每条映射都可以看作是一条路由。
二:实施:
1.将CTMediator导入项目中,然后新建一个控制器RouteVC(会被多处调用);
2.创建Target_xxx对象,并设置传值方法Action_xxx;
3.创建CTMediator的类目,构建路由,创建实现路由的方法;
4.在需要调用RouteVC的控制器中,导入3中的类目,使用CTMediator的路由方法。
具体步骤,和详细解释,可以查看demo。
网友评论