美文网首页
设计模式之装饰者模式

设计模式之装饰者模式

作者: AAA前端 | 来源:发表于2021-10-11 13:20 被阅读0次

    定义

    装饰者提供比继承更有弹性的替代方案。 装饰者用用于包装同接口的对象,不仅允许你向方法添加行为,而且还可以将方法设置成原始对象调用(例如装饰者的构造函数)。

    装饰者用于通过重载方法的形式添加新功能,该模式可以在被装饰者前面或者后面加上自己的行为以达到特定的目的。

    实现

    当脚本运行时,在子类中增加行为会影响原有类所有的实例,而装饰者却不然。取而代之的是它能给不同对象各自添加新行为

    function ConcreteClass() {
        this.performTask = function () {
            this.preTask();
            console.log('doing something');
            this.postTask();
        };
    }
    
    function AbstractDecorator(decorated) {
        this.performTask = function () {
            decorated.performTask();
        };
    }
    
    function ConcreteDecoratorClass(decorated) {
        this.base = AbstractDecorator;
        this.base(decorated);
    
        decorated.preTask = function () {
            console.log('pre-calling..');
        };
    
        decorated.postTask = function () {
            console.log('post-calling..');
        };
    
    }
    
    var concrete = new ConcreteClass();
    var decorator1 = new ConcreteDecoratorClass(concrete);
    var decorator2 = new ConcreteDecoratorClass(decorator1);
    decorator2.performTask();
    

    当我们在装饰者对象上调用performTask时,它不仅具有一些装饰者的行为,同时也调用了下层对象的performTask函数。

    总结

    装饰者模式是为已有功能动态地添加更多功能的一种方式,把每个要装饰的功能放在单独的函数里,然后用该函数包装所要装饰的已有函数对象,因此,当需要执行特殊行为的时候,调用代码就可以根据需要有选择地、按顺序地使用装饰功能来包装对象。优点是把类(函数)的核心职责和装饰功能区分开了。

    来源: 汤姆大叔的博客

    相关文章

      网友评论

          本文标题:设计模式之装饰者模式

          本文链接:https://www.haomeiwen.com/subject/touqoltx.html