<?php
header("Content-Type: text/html; charset=UTF-8");
Class Category {
//组合一维数组(拼成等级形状) 明确标出每个类别的等级,一维
Static Public function unlimitedForLevel ($cate, $html = '-|', $pid = 0, $level = 1) {
$arr = array();
foreach ($cate as $k => $v) {
if ($v['pid'] == $pid) {
$v['level'] = $level;
$v['html'] = str_repeat($html, $level);
$arr[] = $v;
$arr = array_merge($arr, self::unlimitedForLevel($cate, $html, $v['id'], $level + 1));
}
}
return $arr;
}
//组合多维数组 一个总类别下的其他类别,多维
Static Public function unlimitedForLayer ($cate, $name = 'child', $pid = 0) {
$arr = array();
foreach ($cate as $v) {
if ($v['pid'] == $pid) {
if(!empty(self::unlimitedForLayer($cate, $name, $v['id']))){
$v[$name] = self::unlimitedForLayer($cate, $name, $v['id']);
}
$arr[] = $v;
}
}
return $arr;
}
//传递一个子分类ID返回所有的父级分类Id
Static Public function getParentsId($cate, $id) {
$arr = array();
foreach ($cate as $v) {
if ($v['id'] == $id) {
if($v['pid'] != 0){
$arr[] = $v['pid'];
$arr = array_merge(self::getParentsId($cate, $v['pid']), $arr);
}
}
}
return $arr;
}
//传递一个子分类ID返回所有的父级分类信息 有瑕疵,包含了当前子分类的信息
//根据位置,删除后 使用
Static Public function getParents($cate, $id) {
$arr = array();
foreach ($cate as $v) {
if ($v['id'] == $id) {
$arr[] = $v;
if($v['pid'] != 0){
$arr = array_merge(self::getParents($cate, $v['pid']),$arr);
}
}
}
return $arr;
}
//传递一个父级分类ID返回所有子分类ID
Static Public function getChildsId ($cate, $pid) {
$arr = array();
foreach ($cate as $v) {
if ($v['pid'] == $pid) {
$arr[] = $v['id'];
$arr = array_merge($arr, self::getChildsId($cate, $v['id']));
}
}
return $arr;
}
//传递一个父级分类ID返回所有子分类信息
Static Public function getChilds ($cate, $pid) {
$arr = array();
foreach ($cate as $v) {
if ($v['pid'] == $pid) {
$arr[] = $v;
$arr = array_merge($arr, self::getChilds($cate, $v['id']));
}
}
return $arr;
}
public static function test(){
$arr = [
['id'=>1,'name'=>'zjx'],
['id'=>2,'name'=>'xml'],
['id'=>3,'name'=>'hhh'],
];
array_pop($arr);
return $arr;
}
}
$cate = array(
0 => array('id' => 1, 'pid' => 0, 'name' => '中国'),
1 => array('id' => 2, 'pid' => 1, 'name' => '河北省'),
2 => array('id' => 3, 'pid' => 1, 'name' => '山西省'),
3 => array('id' => 4, 'pid' => 3, 'name' => '大同市'),
4 => array('id' => 5, 'pid' => 2, 'name' => '张家口市'),
5 => array('id' => 6, 'pid' => 5, 'name' => '包头'),
6 => array('id' => 7, 'pid' => 6, 'name' => '张家村'),
7 => array('id' => 8, 'pid' => 4, 'name' => '天镇县'),
);
//print_r(Category::unlimitedForLevel($cate));
//var_dump(Category::unlimitedForLayer($cate));
$arr = Category::getParents($cate,8);
array_pop($arr);
var_dump($arr);
//var_dump(Category::getParentsId($cate,7));
//var_dump(Category::getChildsId($cate,2));
//var_dump(Category::getChilds($cate,2));
//var_dump(Category::test());
?>
递归无限极分类
最后编辑于 :
©著作权归作者所有,转载或内容合作请联系作者
- 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
- 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
- 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
推荐阅读更多精彩内容
- 在平时工作中, 经常需要将普通列表数据, 处理成树, 列表数据结构大致如下: 常规实现方式是使用递归模式, 但是在...
- SQL Server 2005开始,我们可以直接通过CTE来支持递归查询,CTE即公用表表达式 百度百科公用表表达...
- 第一步、创建数据库 数据表创建直接复制到mysql管理器里直接运行即可。 DROP TABLE IF EXISTS...