完整树类

<?php
header('content-type:text/html;charset=utf-8');

class Category
{	
		//原始的分类数据
		private $rawList=array();
		//格式化后的分类
		private $formatList=array();
		//格式化的字符
		private $icon = array('│','├','└');
		//字段映射,分类id,上级分类pid,分类名称title,格式化后分类名称fulltitle
		private $field=array();
		
		/*
		功能:构造函数;
		属性:public;
		参数: $field,字段映射,分类id,上级分类pid,分类名称title,格式化后分类名称fulltitle
		依次传递,例如在分类数据表中,分类id,字段名为cid,上级分类pid,字段名称name,希望格式化分类后输出cname,
		  则,传递参数为,$field('cid','pid','name','cname');若为空,则采用默认值。
		*/		
		public function __construct($field=array())
		{			
				$this->field['id']=isset($field['0'])?$field['0']:'id';
				$this->field['pid']=isset($field['1'])?$field['1']:'pid';
				$this->field['title']=isset($field['2'])?$field['2']:'title';
				$this->field['fulltitle']=isset($field['3'])?$field['3']:'fulltitle';
		}

		/*
		功能:返回给定上级分类$pid的所有同一级子分类;
		属性:public;
		参数:上级分类$pid;
		返回:子分类,二维数组;
		*/		
		public function getChild($pid,$data=array())
		{
			$childs=array();
			if(empty($data))
			{
				$data=$this->rawList;
			}
			foreach($data as $Category)
			{
				if($Category[$this->field['pid']]==$pid)
					$childs[]=$Category;
			}
			return $childs;
		}
	
		/*
		功能:得到递归格式化分类;
		属性:public;
		参数:$data,二维数组,起始分类id,默认$id=0;
		返回:递归格式化分类数组;
		*/		
		public function getTree($data,$id=0)
		{
			//数据为空,则返回
			if(empty($data))
				return false;
				
			$this->rawList=array();
			$this->formatList=array();
			$this->rawList=$data;
			$this->_searchList($id);
			return $this->formatList;
		}
			

		private function _searchList($id=0,$space="")
		{
			//下级分类的数组
			$childs=$this->getChild($id);
			//如果没下级分类,结束递归
			if(!($n=count($childs)))
				return;
			$cnt=1;
			//循环所有的下级分类
			for($i=0;$i<$n;$i++)
			{
					$pre="";
					$pad="";
					if($n==$cnt)
					{
						$pre=$this->icon[2];
					}
					else
					{
						$pre=$this->icon[1];
					$pad=$space?$this->icon[0]:"";
				}
				$childs[$i][$this->field['fulltitle']]=($space?$space.$pre:"").$childs[$i][$this->field['title']];
				$this->formatList[]=$childs[$i];
				//递归下一级分类
				$this->_searchList($childs[$i][$this->field['id']],$space.$pad."  ");
				$cnt++;
			}
	}
}
	$data[]=array('cat_id'=>1,'pid'=>0,'name'=>'中国');
	$data[]=array('cat_id'=>2,'pid'=>0,'name'=>'美国');
	$data[]=array('cat_id'=>3,'pid'=>0,'name'=>'韩国');
	$data[]=array('cat_id'=>4,'pid'=>1,'name'=>'北京');
	$data[]=array('cat_id'=>5,'pid'=>1,'name'=>'上海');
	$data[]=array('cat_id'=>6,'pid'=>1,'name'=>'广西');
	$data[]=array('cat_id'=>7,'pid'=>6,'name'=>'桂林');
	$data[]=array('cat_id'=>8,'pid'=>6,'name'=>'南宁');
	$data[]=array('cat_id'=>9,'pid'=>6,'name'=>'柳州');
	$data[]=array('cat_id'=>10,'pid'=>2,'name'=>'纽约');
	$data[]=array('cat_id'=>11,'pid'=>2,'name'=>'华盛顿');
	$data[]=array('cat_id'=>12,'pid'=>3,'name'=>'首尔');
	
	$cat=new Category(array('cat_id','pid','name','cname'));
	$s=$cat->getTree($data);//获取分类数据树结构
	//$s=$cat->getTree($data,1);获取pid=1所有子类数据树结构
	foreach($s as $vo)
	{
	 echo $vo['cname'].'<br>';
	}
?>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值