• 技术文章 >web前端 >js教程

    js设计模式:什么是装饰者模式?js装饰者模式的介绍

    不言不言2018-08-17 16:53:12原创973
    本篇文章给大家带来的内容是关于js设计模式:什么是装饰者模式?js装饰者模式的介绍,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

    什么是装饰者模式?

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

    主要解决:一般的,我们为了扩展一个类经常使用继承方式实现,由于继承为类引入静态特征,并且随着扩展功能的增多,子类会很膨胀。

    何时使用:在不想增加很多子类的情况下扩展类。

    如何解决:将具体功能职责划分,同时继承装饰者模式。

    js装饰者模式应用实例: 1、孙悟空有 72 变,当他变成"庙宇"后,他的根本还是一只猴子,但是他又有了庙宇的功能。 2、不论一幅画有没有画框都可以挂在墙上,但是通常都是有画框的,并且实际上是画框被挂在墙上。在挂在墙上之前,画可以被蒙上玻璃,装到框子里;这时画、玻璃和画框形成了一个物体。

    js装饰者模式优点:装饰类和被装饰类可以独立发展,不会相互耦合,装饰模式是继承的一个替代模式,装饰模式可以动态扩展一个实现类的功能。

    js装饰者模式缺点:多层装饰比较复杂。

    js装饰者模式使用场景: 1、扩展一个类的功能。 2、动态增加功能,动态撤销。

    注意事项:可代替继承。

    js装饰者模式实例

    生活中的例子:天气冷了,就添加衣服来保暖;天气热了,就将外套脱下;这个例子很形象地含盖了装饰器的神韵,随着天气的冷暖变化,衣服可以动态的穿上脱下。

    let wear = function() {
      console.log('穿上第一件衣服')
    }
    
    const _wear1 = wear
    
    wear = function() {
      _wear1()
      console.log('穿上第二件衣服')
    }
    
    const _wear2 = wear
    
    wear = function() {
      _wear2()
      console.log('穿上第三件衣服')
    }
    
    wear()
    
    // 穿上第一件衣服
    // 穿上第二件衣服
    // 穿上第三件衣服

    这种方式有以下缺点:1:临时变量会变得越来越多;2:this 指向有时会出错

    AOP 装饰函数

    // 前置代码
    Function.prototype.before = function(fn) {
      const self = this
      return function() {
        fn.apply(this, arguments)
        return self.apply(this, arguments)
      }
    }
    
    // 后置代码
    Function.prototype.after = function(fn) {
      const self = this
      return function() {
        self.apply(this, arguments)
        return fn.apply(this, arguments)
      }
    }

    用后置代码来实验下上面穿衣服的 demo,

    const wear1 = function() {
      console.log('穿上第一件衣服')
    }
    
    const wear2 = function() {
      console.log('穿上第二件衣服')
    }
    
    const wear3 = function() {
      console.log('穿上第三件衣服')
    }
    
    const wear = wear1.after(wear2).after(wear3)
    wear()
    
    // 穿上第一件衣服
    // 穿上第二件衣服
    // 穿上第三件衣服

    但这样子有时会污染原生函数,可以做点通变

    const after = function(fn, afterFn) {
      return function() {
        fn.apply(this, arguments)
        afterFn.apply(this, arguments)
      }
    }
    
    const wear = after(after(wear1, wear2), wear3)
    wear()

    相关推荐:

    js设计模式:什么是中介者模式?js中介者模式的介绍

    js设计模式:什么是职责链模式?js职责链模式的介绍

    js设计模式:什么是享元模式?js享元模式的介绍

    以上就是js设计模式:什么是装饰者模式?js装饰者模式的介绍的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:js设计模式
    上一篇:js设计模式:什么是中介者模式?js中介者模式的介绍 下一篇:js设计模式:什么是状态模式?js状态模式介绍
    VIP课程(WEB全栈开发)

    相关文章推荐

    • 【腾讯云】年中优惠,「专享618元」优惠券!• 学习JavaScript设计模式之装饰者模式_javascript技巧• 学习JavaScript设计模式之责任链模式_javascript技巧• 学习JavaScript设计模式之策略模式_javascript技巧• javascript设计模式 接口介绍_javascript技巧• JavaScript设计模式之一封装
    1/1

    PHP中文网