设计模式 中介者模式 js java 代码实现中间类

外观模式

大白话:一个人需要买很多东西,就需要来回跑很多趟。那么我们就提供一个超级大超市,需要买的人,或者卖的人,他们不用直接一对多联系,而是去和超市联系一对一联系;

详细解说

  • 核心思想:将一对多关系,-转变为- 一对一

  • 解决什么:一个对象变更是,需要去修改N个关联对象,那么提供一个中间人,去完成这个事情。

  • 何时使用:

    1. N个对象需要对N个对象引用关联. 错综复杂;
    2. 需要统一个中间类,封装多个类行为,
  • 如何实现: 将多个关联的引用删处,新建一个中间者,复杂全部调度;

  • 生活案例:

    1. 中国没有加入TWO之前,一个个国家做生意,而现在是通过TWO使各个国家在上面自由贸易往来
    2. 网上点餐
    3. 机场调度系统

优点:

  1. 降低类的复杂度,让一对多,变为一对一
  2. 个个类之间解耦
  3. 符合迪米特原则

缺点:

  1. 业务越大,中介类越大越复杂

项目实操

  1. Vue中各各兄弟组件同学,通过祖先实例来实现
  2. MVC 三层中,C调度者

实现代码

/** 中介者模式 */
// 中介类
class ChatRoom {
    static setMsg(user, msg) {
        // 处理中间层业务 xxx...
        console.log(`用户:${user}, 发送消息:${msg}`);
    }
}
class ChatUser {
    constructor (name) {
        this.name = name
    }

    sendMessage(msg) {
        ChatRoom.setMsg(this.name, msg)
    }
}

const userA1 = new ChatUser('小红');
const userA12 = new ChatUser('小张');

userA1.sendMessage('你好,有人吗?')
userA12.sendMessage('我看到小红发言了')
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值