• 在不改变原有对象的基础上,通过对其进行包装扩展(添加属性或方法)使原有对象可以满足用户的更复杂需求
  • 装饰者模式注重动态的扩展功能、代理模式注重对象的访问控制,和隐藏代理类的具体细节
  • 装饰者模式将原始对象作为参数传递给装饰者类构造器 ; 代理模式中在代理类中创建实例对象

    动态地给一个对象添加一些额外的职责。就增加功能来说,装饰器模式相比生成子类更为灵活

主要解决:一般我们为了扩展一个类经常使用继承方式实现,由于继承为类引入静态特征,并且随着扩展功能的增多,子类会很膨胀。
何时使用:在不想增加很多子类的情况下扩展类。
如何解决:将具体功能职责划分,同时继承装饰者模式。
应用实例:
1、孙悟空有 72 变,当他变成”庙宇”后,他的根本还是一只猴子,但是他又有了庙宇的功能。
2、不论一幅画有没有画框都可以挂在墙上,但是通常都是有画框的,并且实际上是画框被挂在墙上。在挂在墙上之前,画可以被蒙上玻璃,装到框子里;这时画、玻璃和画框形成了一个物体。

  1. // 被装饰类
  2. class Cricle{
  3. draw(){
  4. console.log('画一个圆形')
  5. }
  6. }
  7. // 装饰类
  8. class Decorator{
  9. constructor(cricle){
  10. this.cricle = cricle;
  11. }
  12. draw(){
  13. this.cricle.draw()
  14. this.addBorder()
  15. }
  16. addBorder(){
  17. console.log('添加边框')
  18. }
  19. }
  20. const cricle = new Cricle()
  21. cricle.draw()
  22. // 添加装饰器、在不影响cricle的情况下为其增加新的功能
  23. const decorator = new Decorator(cricle);
  24. decorator.draw()

总结

优点

  • 扩展性好
  • 符合开闭原则、被装饰类和装饰类相互独立,互不干扰

    缺点

  • 程序复杂、过多的装饰导致程序变得复杂

    使用场景

  • 为一个类扩展功能、为其添加额外的职责

  • 为对象动态的添加或者被动的撤销额外的功能