最近在看組件化相關(guān)內(nèi)容,然后研究了下目前用的比較多的組件化方式,casa大神提供的CTMediator組件化方式。

這里使用下別人的一個(gè)圖片來(lái)說(shuō)明組件化的作用。在組件化之前,各個(gè)模塊之間的依賴很嚴(yán)重,如果想要獨(dú)立某個(gè)功能,難上加難,引入CTMediator的組件化思路之后,很容易解偶,各個(gè)模塊之間相互獨(dú)立,想怎么玩就怎么玩。
下面我說(shuō)下到底要怎么通過(guò)該思路去實(shí)現(xiàn)本地組件之間的相互調(diào)用,源碼的解讀我就不去做解釋了,原理其實(shí)很簡(jiǎn)單,通過(guò)runtime運(yùn)行時(shí)方式,通過(guò)類(class)去執(zhí)行方法(selector)。

這個(gè)是我demo實(shí)踐的項(xiàng)目結(jié)構(gòu),假如
HomeController是我整個(gè)項(xiàng)目的主頁(yè),它需要調(diào)用其他項(xiàng)目團(tuán)隊(duì)開(kāi)發(fā)的組件ModuleA,我們只需要在咱們的項(xiàng)目中創(chuàng)建一個(gè)基于CTMediator的類別,同時(shí)組件ModuleA只需要?jiǎng)?chuàng)建一個(gè)中間類Target_ModuleA就可以實(shí)現(xiàn)從咱們的App調(diào)用組件的功能,組件團(tuán)隊(duì)又可以獨(dú)立完成自己的內(nèi)容,完全符合架構(gòu)思想“開(kāi)閉原則”。
這里要注意的是:在組件創(chuàng)建公開(kāi)API的時(shí)候,類名需要以Target_開(kāi)頭,方法名需要以Action_開(kāi)頭,原因是因?yàn)樵创a里的方法是需要根據(jù)此開(kāi)頭內(nèi)容判斷Class和Method的,可以自己去研究下源碼里的方法- (id)performTarget:(NSString *)targetName action:(NSString *)actionName params:(NSDictionary *)params shouldCacheTarget:(BOOL)shouldCacheTarget;
下面是我各個(gè)文件的代碼,供參考
CTMediator+InteractiveModule.m文件內(nèi)容:
#import "CTMediator+InteractiveModule.h"
@implementation CTMediator (InteractiveModule)
- (UIViewController *)interactiveModuleA:(NSDictionary *)params{
UIViewController *moduleAController = [self performTarget:@"ModuleA" action:@"nativeCallModuleA" params:params shouldCacheTarget:NO];
return moduleAController;
}
@end
Target_ModuleA.m文件內(nèi)容:
#import "Target_ModuleA.h"
#import "OneViewController.h"
@implementation Target_ModuleA
- (UIViewController *)Action_nativeCallModuleA:(NSDictionary *)params
{
// 組件控制內(nèi)部跳轉(zhuǎn)
OneViewController *controller = [OneViewController new];
controller.params = params;
return controller;
}
@end