解耦选型

"一个组件要有一个插头和一个插座" ---- 达拉崩吧斑得贝迪卜多比鲁翁

组件解耦交互在项目中的应用场景(注:"我"代表一个组件,"你"代表另外一个组件)
- 场景一(接口):
    - 实现在我这里;
    - 暴露API给你,在你需要的时候调用;
- 场景二(广播):
    - 调用在我这里;
    - 当我做出特定动作的时候会调用相应的方法;
    - 而如果你需要响应我的动作,那么你需要实现对应的方法

一、URL解耦

  • 思路

    URL Scheme解耦的思路很简单:

    • 通过自定义Scheme来做URL拦截
    • 拦截后解析URL中携带的参数
    • 根据解析后的参数,通过配置文件查询映射模块、映射类
    • 最终调起映射模块、映射类特定的方法
    • 其中通过Context上下文缓存组件交互方法的返回数据,通过completeBlock回调上下文,实现组件间数据回传交互
  • 关键代码解读

    • 创建映射配置文件


      URL配置
    • 外部通过自定义Scheme来统跳方法
      调用统跳方法
    • 统跳方法内部解析Scheme,通过配置文件将方法分发到对应组件
      • 解析url:-(void)openUrl:params:
        image
      • 进入组件:-(void)jumpToModule:pageId:context:
        image
        • 查找组件:-(void)componentWithName:
          image
        • 读取组件类(初始化时执行):-(void)loadAllComponnet
          image
        • 进入页面:-(void)jumpPageWithID:context:callBack:
          image
        • 查询页面:-(void)pageWithID:context:
          image
        • 对应组件内部映射方法被调起


          image
  • 评价

    • 可以实现组件间解耦
    • 配置文件以字符串形式映射,可读性查,多组件维护成本高
    • 不符合项目初衷

二、默认实现类解耦

  • 前言

    • Swift语法出现后,我们发现官方已经支持protocol方法的默认实现,而OC并不支持
    • @defs()是Object-C保留关键字,但在语法迭代过程中已经接近废弃,但在N年前,ProtocolKit使这个关键字重新复活,使用ProtocolKit配合@defs()关键字则成为了"默认实现类"解耦的核心思路
  • 思路

    • 定义协议类,下沉到协议层
    • 定义实现类,保留在组件内,同时通过@defs(<protocol>)生成中间类
    • 外部import协议类,并遵守协议后,即可使用self来调用协议中的API
      (protocolKit:旧版为动态添加imp来实现方法注入,新版为消息转发来实现方法间接调用)
  • 关键代码解读

    • protocolKit重定义了OC保留的关键字defs,当使用@defs(<protocol>)配合@end修饰一个协议后,相当于创建了一个中间类的声明和实现
      image
    • 而protocolKit指定了一个次级函数入口,来为所有遵守<protocol>的类动态插入了中间类所定义的方法实现,这里会影响性能
      image
    • 创建协议类,下沉到协议层


      image
    • 定义实现类,在其中使用@defs(<protocol>)生成中间类
      image
    • import协议


      image
    • 使用self调用协议中的API实现组件间交互
      image
  • 评价

    • 可以实现组件间解耦
    • 轻量级,只有一个类的代码量
    • 性能较低,作者后续将实现方式从"注入实现"调整为"消息转发"后性能有提升
    • 可读性差,所有协议方法均以self调用
    • 不符合项目初衷

三、协议式解耦

  • 前言

  • 思路

    • 创建BeeHiveProtocol下沉到协议层,定义组件API
    • 创建实现类,存放在组件内部,外部使用BeeHiveImpl通过泛型的方式来调用BeeHiveProtocol中定义的API
    • 创建serviceClient下沉到协议层,定义组件广播
    • 组件内部使用NOTIFY_SERVICE_CLIENT()发送广播,组件外部根据需要,来是想广播协议中定义的方法
  • 实际应用

    • BeeHive协议API:

      • 创建协议类,下沉到协议层


        image
      • 组件内部创建实现类


        image
      • 外部import协议后使用泛型调用


        image
    • ServiceCenter广播:

      • 创建协议类,下沉到协议层


        image
      • 组件内部通过NOTIFY_SERVICE_CLIENT()调用


        image
      • 外部import协议后,监听-实现协议方法-移除监听
        • 遵守协议


          image
        • 监听与移除


          image
        • 方法实现


          image
  • 评价

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

推荐阅读更多精彩内容