KZWFoudation系列之Router的设计
本來是要寫我自己用的router的,但是現在這個有點落后了, 所以這篇文章主要說下CTMediator這個router的設計,我覺得這個比較符合當下我對router理解。
它主要有一個類CTMediator,里面有3個方法,performActionWithUrl,performTarget和releaseCachedTargetWithTargetName前2個的作用主要是返回controller,后一個是清除緩存。performActionWithUrl是根據url解析出所需要的數據在調用performTarget生成controller,下面來看下performTarget這個主要方法:
- (id)performTarget:(NSString *)targetName action:(NSString *)actionName params:(NSDictionary *)params shouldCacheTarget:(BOOL)shouldCacheTarget {NSString *targetClassString = [NSString stringWithFormat:@"Target_%@", targetName];NSString *actionString = [NSString stringWithFormat:@"Action_%@:", actionName];Class targetClass;NSObject *target = self.cachedTarget[targetClassString];if (target == nil) {targetClass = NSClassFromString(targetClassString);target = [[targetClass alloc] init];}SEL action = NSSelectorFromString(actionString);if (target == nil) {// 這里是處理無響應請求的地方之一,這個demo做得比較簡單,如果沒有可以響應的target,就直接return了。實際開發過程中是可以事先給一個固定的target專門用于在這個時候頂上,然后處理這種請求的[self NoTargetActionResponseWithTargetString:targetClassString selectorString:actionString originParams:params];return nil;}if (shouldCacheTarget) {self.cachedTarget[targetClassString] = target;}if ([target respondsToSelector:action]) {return [self safePerformAction:action target:target params:params];} else {// 有可能target是Swift對象actionString = [NSString stringWithFormat:@"Action_%@WithParams:", actionName];action = NSSelectorFromString(actionString);if ([target respondsToSelector:action]) {return [self safePerformAction:action target:target params:params];} else {// 這里是處理無響應請求的地方,如果無響應,則嘗試調用對應target的notFound方法統一處理SEL action = NSSelectorFromString(@"notFound:");if ([target respondsToSelector:action]) {return [self safePerformAction:action target:target params:params];} else {// 這里也是處理無響應請求的地方,在notFound都沒有的時候,這個demo是直接return了。實際開發過程中,可以用前面提到的固定的target頂上的。[self NoTargetActionResponseWithTargetString:targetClassString selectorString:actionString originParams:params];[self.cachedTarget removeObjectForKey:targetClassString];return nil;}}} } 復制代碼targetName就是調用接口的Object,actionName就是調用方法的SEL,params是參數,shouldCacheTarget代表是否需要緩存,如果需要緩存就把target存起來,Key是targetClassString,Value是target。
通過這種方式進行改造的,外面調用的方法都很統一,都是調用performTarget: action: params: shouldCacheTarget:。第三個參數是一個字典,這個字典里面可以傳很多參數,只要Key-Value寫好就可以了。處理錯誤的方式也統一在一個地方了,target沒有,或者是target無法響應相應的方法,都可以在Mediator這里進行統一出錯處理。
但是在實際開發過程中,不管是界面調用,組件間調用,在Mediator中需要定義很多方法。于是做作者又想出了建議我們用Category的方法,對Mediator的所有方法進行拆分,這樣就就可以不會導致Mediator這個類過于龐大了。所以可以看下demo中的#import "CTMediator+CTMediatorModuleAActions.h"是怎么管理的。
代碼地址:https://github.com/casatwy/CTMediator
參考文章:https://lpd-ios.github.io/2017/02/26/iOS-Router/
總結
以上是生活随笔為你收集整理的KZWFoudation系列之Router的设计的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: [Spring Cloud Task]6
- 下一篇: 重新理解 Monad