Mediator (中间件、解耦神器、组件化、设计模式)

Mediator用过的朋友都知道它的优缺点,这篇文章我们来解决它存在的缺点 首先,我们列举一下mediator存在的缺点: 1.每新增一个模块,就要补充一个Category 2.模块A 想要调用 模块B,模块B需要暴漏需要调用的方法 3.参数硬编码问题 4.命名规则并不美观且相对复杂,每个Target都得加Target_A,每个Action都得加Action_ 5.编译时候没有类型检查,运行的时候才能发现问题

这里我们提供NSObject+Mediator,解决上面的部分问题: 可以点击查看demo

demo演示一个常用场景:tableView列表,我们希望通过传参viewController、Cell、数据源data来封装一个通用功能

[NSObject performTarget:<target>.classString action:<action> object:<cell> object:<viewController>]; 这个方法封装类(TableViewDemo)作为target,action方法也不需要暴漏出来,这个方法主要用来传参并返回对象

[obj performAction:<action> object:data]; 刷新tableView数据源调用该方法

以上就是核心代码,完美解决1、2、4问题,但是硬编码问题似乎更严重了,这里的target和action都使用字符串,目前的解决思路是字符串映射+消息转发(resolveClassMethod)去解决参考demo 最后的类型检查是硬伤,毕竟Mediator的核心就是运行时。

此外说明一下:NSObject+Mediator如何使用

NSObject+Mediator可以调用绝大数方法:

比如我们要初始化一个label UILabel *label = [UILabel performAction:@"new"]

比如自定义的类 CustomLabel继承UILabel,UILabel *label = [NSObject performTarget:@"CustomLabel".classString action:@"new"]

其中字符串方法classString是用来区分实例方法和类方法的; objects是参数大于2个时,使用字典参数,key从@"1"依次递增

给一个关注支持一下,谢谢

有问题可以给我留言

相关推荐
前端若水3 小时前
会话管理:创建、切换、删除对话历史
前端·人工智能·python·react.js
Bigger3 小时前
mini-cc:一个轻量级 AI 编程助手的诞生
前端·ai编程·claude
涵涵(互关)3 小时前
Naive-ui树型选择器只显示根节点
前端·ui·vue
BY组态3 小时前
Ricon组态系统最佳实践:从零开始构建物联网监控平台
前端·物联网·iot·web组态·组态
BY组态4 小时前
Ricon组态系统vs传统组态软件:为什么选择新一代Web组态平台
前端·物联网·iot·web组态·组态
SoaringHeart4 小时前
Flutter进阶:OverlayEntry 插入图层管理器 NOverlayZIndexManager
前端·flutter
放下华子我只抽RuiKe54 小时前
React 从入门到生产(四):自定义 Hook
前端·javascript·人工智能·深度学习·react.js·自然语言处理·前端框架
IT_陈寒5 小时前
Redis缓存击穿把我整不会了,原来还有这手操作
前端·人工智能·后端
idcu6 小时前
深入 Lyt.js 组件系统:L2 渲染引擎层的核心
前端·typescript
这是程序猿6 小时前
Spring Boot自动配置详解
java·大数据·前端