PHP-设计模式-组合模式

组合模式:将对象组合成树形结构来表现”部分-整体“的层次结构。
目的(重点):使得客户以一致的方式处理单个对象以及对象的组合。

<?php 
header("Content-type: text/html; charset=utf-8");
//定义抽象类,抽象方法,方法参数根据‘里氏替换原则’传递父类。
abstract class node{
    abstract function addnode(node $obj);
    abstract function removenode(node $obj);
    abstract function show($str);//$str用来保存输出样式
}
class level_1 extends node{
    public $nodearr = array();//子节点(对象)保存在数组中
    public $name = null;      //$name保存当前节点名称
    function __construct($name){
        $this->name = $name;
    }
    /*
    *方法中的参数为子节点对象,
    */
    public function addnode(node $obj){        
        array_push($this->nodearr,$obj);//将节点对象保存到数组中
    }
    public function removenode(node $obj){
        $a = array_search($obj,$this->nodearr);
        unset($this->nodearr[$a]);
    }
    public function show($str=''){
        echo $this->name."<br>";
        $str.= "|->";
        //$nodearr 数组中可能为多维数组,即改对象为多级结构。此处使用递归。
        foreach($this->nodearr as $arr){
            echo $str;
            $arr->show($str);
        }
    }
}
//叶子节点不再有子节点,只实现输出。
class level_2 extends node{
    public $name = null;
    function __construct($name){
        $this->name = $name;
    }
    function addnode(node $obj){return false;}
    function removenode(node $obj){return false;}
    function show($str){
        echo $this->name.'<br>';
        }
}
    $p = new level_1('手机');
    $p1 = new level_2('华为'); 
    //$p->addnde($p); //不能添加自己为自己的子节点,会出现无限递归。
    $p->addnode($p1);
    $p->addnode($p2);
    $p->show();//两层结构
    $com = new level_1('数码');
    $com->addnode($p);
    $com->show();//三层结构

?> 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值