組件化CTMediator的封裝使用

前言:仔細看了又看CTMediator的Demo,在這個過程中突然想到了Moya。所以我下面介紹的將基于Moya的思想的封裝。

1. 新建一個協(xié)議:內(nèi)部包含CTMediator的所需參數(shù)。如下:

// 使用方式:創(chuàng)建枚舉, 遵守該協(xié)議,根據(jù)不同case設置下列參數(shù)的值

public protocol SPTargetType {
    /// 參數(shù)
    var commonParams: [String: Any] { get }
    /// 組件名稱
    var moudle: String { get }
    /// 響應者名稱
    var target: String { get }
    /// 方法名稱
    var action: String { get }
    /// 是否緩存
    var shouldCacheTarget: Bool { get }
}

2. 稍微封裝一下CTMediator的使用方法:

  • 這里要解釋一下為什么要在方法內(nèi)部去設置callback、kCTMediatorParamsKeySwiftTargetModuleName 這兩個參數(shù),因為使用者大概率是不用去關心這兩個參數(shù)的,所以我選擇在方法內(nèi)部去賦值。
public class SPMediator {
    
    @discardableResult
    static func performTarget(_ target: MediatorService, callback:@escaping (Any) -> Void) -> Any? {
        let callbackParams: [String: Any] = ["callback": callback, kCTMediatorParamsKeySwiftTargetModuleName: target.service.moudle]
        return CTMediator.sharedInstance()?.performTarget(
            target.service.target,
            action: target.service.action,
            params: target.service.commonParams.merging(callbackParams, uniquingKeysWith: { _ , _ in }),
            shouldCacheTarget: target.service.shouldCacheTarget)
    }
}

3. 創(chuàng)建設置參數(shù)枚舉, 并遵守協(xié)議(1),設置協(xié)議參數(shù):

public enum BalanceService: SPTargetType {
    
    case balance
    
    case test([String: Any])
    
    public var commonParams: [String : Any] {
        switch self {
        case .balance:
            return ["animation": true]
        case .login(let params):
            return ["id": params["id"] ?? ""]
        }
        
    }
    
    /// 區(qū)分每個業(yè)務模塊
    public var moudle: String {
        
        switch self {
        default:
            return "SPRouteModule"
        }
    }
    
    public var target: String {
        
        switch self {
        default:
            return "Balance"
        }
    }
    
    public var action: String {
        
        switch self {
        case .balance:
            return "Test_ViewController"
        case .login(_):
            return "Login_ViewController"
        }
    }
    
    public var shouldCacheTarget: Bool {
        return true
    }
    
}

4. 使用:

比如我需要Balance的控制器:

guard let result = (SPMediator.performTarget(MediatorService.balance(BalanceService.balance)) { (params) in
            print(params)
        }) as? UIViewController else {
            return
        }
  • 回調適用于耗時、異步操作等,其它情況直接拿到返回值然后轉成自己需要的Class就可以了。

  • 我這里使用的是MediatorService,因為我最后針對每個Service做了一層封裝,統(tǒng)一調用入口。

?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容