定义:
是用于把一组相似的对象当作一个单一的对象。组合模式依据树形结构来组合对象,用来表示部分以及整体层次。这种类型的设计模式属于结构型模式,它创建了对象组的树形结构。
应用场景:
部分、整体场景,如树形菜单,文件、文件夹的管理
通俗解释:
组合模式,就是在一个对象中包含其他对象,这些被包含的对象可能是终点对象(不再包含别的对象),也有可能是非终点对象(其内部还包含其他对象,或叫组对象),我们将对象称为节点,即一个根节点包含许多子节点,这些子节点有的不再包含子节点,而有的仍然包含子节点,以此类推。很明显,这是树形结构,终结点叫叶子节点,非终节点(组节点)叫树枝节点,第一个节点叫根节点。同时也类似于文件目录的结构形式:文件可称之为终节点,目录可称之为非终节点(组节点)。
实现如图所示的树形结构
interface Node{
public function add(Node $node);
}
class Branch implements Node{
static $i = 0;
public $name;
public $node_list;
public function __construct($name){
$this->name = $name;
}
public function add(Node $node){
$this->node_list[] = $node;
}
}
class Leaf implements Node{
public $name;
public function __construct($name){
$this->name = $name;
}
public function add(Node $node){
throw new Exception("Leaf don't add sub nodes");
}
}
$branch = new Branch("主干");
$branch_left = new Branch("左树枝");
$branch_right = new Branch("右树枝");
$leaf1 = new Leaf("左第一片树叶");
$leaf2 = new Leaf("左第二片树叶");
$branch->add($branch_left);
$branch->add($branch_right);
$branch_left->add($leaf1);
$branch_left->add($leaf2);
print_r($branch);
输出:
Branch Object
(
[name] => 主干
[node_list] => Array
(
[0] => Branch Object
(
[name] => 左树枝
[node_list] => Array
(
[0] => Leaf Object
(
[name] => 左第一片树叶
)
[1] => Leaf Object
(
[name] => 左第二片树叶
)
)
)
[1] => Branch Object
(
[name] => 右树枝
[node_list] =>
)
)
)