[TOC]
为子系统中的一组接口提供一个一致的界面,外观模式定义了一个高层接口,这个接口使得这一子系统更加容易使用。
主要解决:降低访问复杂系统的内部子系统时的复杂度,简化客户端之间的接口。
何时使用:
1、客户端不需要知道系统内部的复杂联系,整个系统只需提供一个”接待员”即可。
2、定义系统的入口。
如何解决:客户端不与系统耦合,外观类与系统耦合。
关键代码:在客户端和复杂系统之间再加一层,这一层将调用顺序、依赖关系等处理好。
应用实例:
1、去医院看病,可能要去挂号、门诊、划价、取药,让患者或患者家属觉得很复杂,如果有提供接待人员,只让接待人员来处理,就很方便。
外观模式与中介者模式
点击
> **通过外观模式去暴露一个绑定事件的方式、里面统一做不同环境的兼容性!**
<a name="rDcXp"></a>
### 案例2
```javascript
class SystemA {
drow () {
console.log('systemA')
}
}
class SystemB {
write () {
console.log('systemB')
}
}
// 通过外观模式访问子系统的接口 统一处理
class Facade {
constructor() {
this.systemA = new SystemA()
this.systemB = new SystemB()
}
handler (type) {
if (type == 'A') {
this.systemA.drow()
} else {
this.systemB.write()
}
}
}
const client = new Facade()
client.handler('A') // systemA
client.handler('B') // systemB