zoukankan      html  css  js  c++  java
  • 设计模式(六)--装饰器模式

    装饰器模式(Decorator Pattern)允许向一个现有的对象添加新的功能,同时又不改变其结构。这种类型的设计模式属于结构型模式,它是作为现有的类的一个包装。

    这种模式创建了一个装饰类,用来包装原有的类,并在保持类方法签名完整性的前提下,提供了额外的功能。

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

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

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

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

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

    简单实现:有一篇文章,编辑人员添加描述,seo人员添加关键词。

    class baseArt{
        public $content;
        public function __construct($content){
            $this->content=$content;
        }
        public function decorate(){
            return $this->content;
        }
    }
    
    class bianArt extends baseArt{
        public function __construct(baseArt $art){
            $this->art=$art;
            $this->decorate();
        }
    
        public function decorate() {
            return $this->art->decorate().'添加描述';
        }
    }
    
    class seoArt extends baseArt{
        public function __construct(baseArt $art){
            $this->art=$art;
            $this->decorate();
        }
    
        public function decorate() {
            return $this->art->decorate().'添加关键词';
        }
    }
    
    $bian=new bianArt(new seoArt(new baseArt('原始文章')));
    echo $bian->decorate();

    详细参考:http://video.1kejian.com/video/?79018-0-13.html

  • 相关阅读:
    jQuery中Ajax事件beforesend及各参数含义 转
    如何组织好js代码 转
    C# 几种HtmlEncode的区别
    [转]建议Font-Size使用em单位控制大小
    JavaScript charAt() 方法
    Js中 关于top、clientTop、scrollTop、offsetTop的用法
    jquery mobile 的4个初始化事件
    JS操作JSON总结
    .html(),.text()和.val()的使用
    netstat 显示当前网络连接的统计信息
  • 原文地址:https://www.cnblogs.com/Caoxt/p/10138141.html
Copyright © 2011-2022 走看看