php 分类代码,PHP 无限级分类

/**

* 无限级分类 类

*/

class Category{

/**

* 返回一维数组

* @param [type] $cate 要递归的数组

* @param string $html 子级分类前要显示的缩进符号。默认 '─'

* @param integer $pid 父级分类ID。默认为 0,表示顶级分类

* @param integer $level level级,配合 $html 显示足够的缩进。默认为 1,表示顶级分类

* @return [type] [description]

*/

static public function unlimitedForLevel($cate, $html = '─', $pid = 0, $level = 1){

$arr = array();

foreach($cate as $v){

if($v['pid'] == $pid){

$v['level'] = $level;

$v['html'] = str_repeat($html, $level - 1);

$arr[] = $v;

$arr = array_merge($arr, $this->unlimitedForLevel($cate, $html, $v['id'], $level + 1));

}

}

return $arr;

}

/**

* 返回多维数组

* @param [type] $cate 要递归的数组

* @param string $name 子级分类在父分类数组中的 key

* @param integer $pid 父级分类ID。默认为0,表示顶级分类

* @return [type] [description]

*/

static public function unlimitedForlayer($cate, $name = 'child', $pid = 0){

$arr = array();

foreach($cate as $v){

if( $v['pid'] == $pid){

$v[$name] = self::unlimitedForlayer($cate, $name, $v['id']);

$arr[] = $v;

}

}

return $arr;

}

/**

* 传递子分类ID返回所有父级分类

* @param [type] $cate 要递归的数组

* @param [type] $id 子分类ID

* @return [type] [description]

*/

static public function getParents($cate, $id){

$arr = array();

foreach($cate as $v){

if($v['id'] == $id){

$arr[] = $v;

$arr = array_merge(self::getParents($cate, $v['pid']), $arr);

}

}

return $arr;

}

/**

* 传递父级分类ID返回所有子分类ID

* @param [type] $cate 要递归的数组

* @param [type] $pid 父级分类ID

* @return [type] [description]

*/

static public function getChildrenId($cate, $pid){

$arr = array();

foreach($cate as $v){

if($v['pid'] == $pid){

$arr[] = $v['id'];

$arr = array_merge($arr, self::getChildrenId($cate, $v['id']));

}

}

return $arr;

}

/**

* 传递父级分类ID返回所有子级分类

* @param [type] $cate 要递归的数组

* @param [type] $pid 父级分类ID

* @return [type] [description]

*/

static public function getChildren($cate, $pid){

$arr = array();

foreach($cate as $v){

if($v['pid'] == $pid){

$arr[] = $v;

$arr = array_merge($arr, self::getChildren($cate, $v['id']));

}

}

return $arr;

}

}

?>

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值