PHP无限级分类实现(递归+非递归)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
<?php 
/**
 * Created by PhpStorm.
 * User: qishou
 * Date: 15-8-2
 * Time: 上午12:00
 */ 
//准备数组,代替从数据库中检索出的数据(共有三个必须字段id,name,pid) 
header("content-type:text/html;charset=utf-8"); 
$categories = array
    array('id'=>1,'name'=>'电脑','pid'=>0), 
    array('id'=>2,'name'=>'手机','pid'=>0), 
    array('id'=>3,'name'=>'笔记本','pid'=>1), 
    array('id'=>4,'name'=>'台式机','pid'=>1), 
    array('id'=>5,'name'=>'智能机','pid'=>2), 
    array('id'=>6,'name'=>'功能机','pid'=>2), 
    array('id'=>7,'name'=>'超级本','pid'=>3), 
    array('id'=>8,'name'=>'游戏本','pid'=>3), 
); 
   
/*======================非递归实现========================*/ 
$tree = array(); 
//第一步,将分类id作为数组key,并创建children单元 
foreach($categories as $category){ 
    $tree[$category['id']] = $category
    $tree[$category['id']]['children'] = array(); 
//第二步,利用引用,将每个分类添加到父类children数组中,这样一次遍历即可形成树形结构。 
foreach($tree as $key=>$item){ 
    if($item['pid'] != 0){ 
        $tree[$item['pid']]['children'][] = &$tree[$key];//注意:此处必须传引用否则结果不对 
        if($tree[$key]['children'] == null){ 
            unset($tree[$key]['children']); //如果children为空,则删除该children元素(可选) 
        
    
////第三步,删除无用的非根节点数据 
foreach($tree as $key=>$category){ 
    if($category['pid'] != 0){ 
        unset($tree[$key]); 
    
   
print_r($tree); 
   
/*======================递归实现========================*/ 
$tree = $categories
function get_attr($a,$pid){ 
    $tree = array();                                //每次都声明一个新数组用来放子元素 
    foreach($a as $v){ 
        if($v['pid'] == $pid){                      //匹配子记录 
            $v['children'] = get_attr($a,$v['id']); //递归获取子记录 
            if($v['children'] == null){ 
                unset($v['children']);             //如果子元素为空则unset()进行删除,说明已经到该分支的最后一个元素了(可选) 
            
            $tree[] = $v;                           //将记录存入新数组 
        
    
    return $tree;                                  //返回新数组 
echo "<br/><br/><br/>"
   
print_r(get_attr($tree,0)); 

  

posted @   小小强学习网  阅读(615)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 25岁的心里话
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
点击右上角即可分享
微信分享提示