用一个中介对象来封装一系列的对象交互,中介者使各对象不需要显式地相互引用,从而使其耦合松散,而且可以独立地改变它们之间的交互

主要解决:对象与对象之间存在大量的关联关系,这样势必会导致系统的结构变得很复杂,同时若一个对象发生改变,我们也需要跟踪与之相关联的对象,同时做出相应的处理。
何时使用:多个类相互耦合,形成了网状结构。
如何解决:将上述网状结构分离为星型结构。
应用实例:
1、中国加入 WTO 之前是各个国家相互贸易,结构复杂,现在是各个国家通过 WTO 来互相贸易。
2、机场调度系统。
3、MVC 框架,其中C(控制器)就是 M(模型)和 V(视图)的中介者。
中介模式 - 图1

在程序中,也许一个对象会和其嘎10个对象打交道,所以会保持10个对象的引用,当程序的规模增大对象会越来越多,他们之间的关系也越来越复杂,难免形成网状的交叉引用! 增加一个中介者对象后所有的相关对象都通过中介者对象进行通信,而不是互相引用.

  1. class A {
  2. constructor() {
  3. this.number = 0
  4. }
  5. setNumber(number, mediator) {
  6. this.number = number
  7. if (mediator) {
  8. mediator.setB()
  9. }
  10. }
  11. }
  12. class B {
  13. constructor() {
  14. this.number = 0
  15. }
  16. setNumber(number, mediator) {
  17. this.number = number
  18. if (mediator) {
  19. mediator.setA()
  20. }
  21. }
  22. }
  23. class Mediator {
  24. constructor(a, b) {
  25. this.a = a
  26. this.b = b
  27. }
  28. setA() {
  29. const number = this.b.number
  30. this.a.setNumber(number / 100)
  31. }
  32. setB() {
  33. const number = this.a.number
  34. this.b.setNumber(number * 100)
  35. }
  36. }
  37. const a = new A()
  38. const b = new B()
  39. const mediator = new Mediator(a, b)
  40. a.setNumber(100, mediator)
  41. console.log(a.number, b.number)
  42. b.setNumber(100, mediator)
  43. console.log(a.number, b.number)

总结

优点

  • 降低了类的复杂度,将一对多转化成了一对一
  • 各个类之间的解耦
  • 符合迪米特原则

    缺点

  • 中介者会庞大,变得复杂难以维护