- 在不改变原有对象的基础上,通过对其进行包装扩展(添加属性或方法)使原有对象可以满足用户的更复杂需求
- 装饰者模式注重动态的扩展功能、代理模式注重对象的访问控制,和隐藏代理类的具体细节
- 装饰者模式将原始对象作为参数传递给装饰者类构造器 ; 代理模式中在代理类中创建实例对象
动态地给一个对象添加一些额外的职责。就增加功能来说,装饰器模式相比生成子类更为灵活
主要解决:一般我们为了扩展一个类经常使用继承方式实现,由于继承为类引入静态特征,并且随着扩展功能的增多,子类会很膨胀。
何时使用:在不想增加很多子类的情况下扩展类。
如何解决:将具体功能职责划分,同时继承装饰者模式。
应用实例:
1、孙悟空有 72 变,当他变成”庙宇”后,他的根本还是一只猴子,但是他又有了庙宇的功能。
2、不论一幅画有没有画框都可以挂在墙上,但是通常都是有画框的,并且实际上是画框被挂在墙上。在挂在墙上之前,画可以被蒙上玻璃,装到框子里;这时画、玻璃和画框形成了一个物体。
// 被装饰类class Cricle{draw(){console.log('画一个圆形')}}// 装饰类class Decorator{constructor(cricle){this.cricle = cricle;}draw(){this.cricle.draw()this.addBorder()}addBorder(){console.log('添加边框')}}const cricle = new Cricle()cricle.draw()// 添加装饰器、在不影响cricle的情况下为其增加新的功能const decorator = new Decorator(cricle);decorator.draw()
