iOS开发中组件化之业务组件间通讯方式之Target-Action

既然是组件间通讯,这里所说的组件就是业务组件。

跳转

实际就是控制器A跳转到控制器B,控制器B作为某个组件的一个入口。
我们使用的方式是Target-Action,用到了一个三方CTMediator

0.组件化.png

看图,为了简化我们假设某个组件只有一个控制器SecondViewController。
要想不引入SecondViewController而跳到该控制器且可以传值,我们还需要额外的两个类CTMediator+TASecondVC和Target_TASecondVC。

CTMediator+TASecondVC(负责传值和获取目标控制器)

这是一个CTMediator的分类,我们在跳到SecondViewController的时候需要使用此分类的方法,它的方法是暴露给其他组件调用者的。

Target_TASecondVC(负责传值和返回目标控制器)

这个类是CTMediator+TASecondVC需要用到的,它会返回我们要跳转的VC以及传值给该VC。这个类是不会暴露给其他组件调用者的。

使用

现在我们要跳转到SecondViewController

   UIViewController * vc = [[CTMediator sharedInstance] secondVCWithName:@"我"];
    if (vc) {
        [self presentViewController:vc animated:YES completion:nil];
    }

代码很简单,并且没有SecondViewController的出现,其中的secondVCWithName方法是CTMediator+TASecondVC分类中的方法,参数是我们传的值。
我们看下secondVCWithName:方法的具体实现:

 - (UIViewController *)secondVCWithName:(NSString *)name{
    NSMutableDictionary * parameters = [NSMutableDictionary dictionary];
    parameters[@"name"] = name;
    return [self performTarget:@"TASecondVC" action:@"SecondVC" params:parameters shouldCacheTarget:NO];
}

这个类虽然需要Target_TASecondVC的支持,但并没有引入该类,而是通过调用CTMedia的方法实现的,CTMedia中使用runtime来实现找到某个类并调用这个类的某个方法。其调用的方法就是- (id)performTarget:(NSString *)targetName action:(NSString *)actionName params:(NSDictionary *)params shouldCacheTarget:(BOOL)shouldCacheTarget。
performTarget后的参数是方法调用类,action后的参数该要要调用的方法。

看Target_TASecondVC的具体实现。

  - (UIViewController *)Action_SecondVC:(NSDictionary *)parameters{
SecondViewController * secondVC = [SecondViewController new];
secondVC.name = parameters[@"name"];
return secondVC;
}
注意:

你会发现target的参数是"TASecondVC",而我们的类名是Target_TASecondVC,action的参数是"SecondVC",而我们实际调用的方法名是Action_SecondVC。感觉类名少了"Target_",方法名少了·"Action_"这是因为CTMedia内部为类名和方法加了这两个前缀。

正向传值

正向传值就像我们前面介绍的直接把参数拼接在方法里就好了。

反向传值

反向传值我们需要利用到block回调,将block作为方法的一个参数。
这里列出CTMedia分类的方法和Target_类的方法

  - (UIViewController *)thirdVCWithName:(NSString *)name callBack:(dispatch_block_t)callBack{
NSMutableDictionary * parameters = [NSMutableDictionary dictionary];
parameters[@"name"] = name;
parameters[@"callBack"] = callBack;
return [self performTarget:@"TAThirdVC" action:@"thirdVC" params:parameters shouldCacheTarget:NO];
}

  - (UIViewController *)Action_thirdVC:(NSDictionary *)parameters{
ThirdViewController * thirdVC = [ThirdViewController new];
thirdVC.name = parameters[@"name"];
thirdVC.callBack = parameters[@"callBack"];
return thirdVC;
}

问题

传参的时候有硬编码

附上一个小demo供大家参考:https://github.com/yangguanghei/Media-demo

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,324评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,303评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,192评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,555评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,569评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,566评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,927评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,583评论 0 257
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,827评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,590评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,669评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,365评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,941评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,928评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,159评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,880评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,399评论 2 342