本文实例讲述了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
|
<?php
//$data[]=array('id'=>1,'parentid'=>0,'name'=>'中国','img'=>'52091199');
$data []= array ( 'id' =>1, 'parentid' =>0, 'name' => '中国' );
$data []= array ( 'id' =>2, 'parentid' =>0, 'name' => '美国' );
$data []= array ( 'id' =>3, 'parentid' =>0, 'name' => '韩国' );
$data []= array ( 'id' =>4, 'parentid' =>1, 'name' => '北京' );
$data []= array ( 'id' =>5, 'parentid' =>1, 'name' => '上海' );
$data []= array ( 'id' =>6, 'parentid' =>1, 'name' => '广西' );
$data []= array ( 'id' =>7, 'parentid' =>6, 'name' => '桂林' );
$data []= array ( 'id' =>8, 'parentid' =>6, 'name' => '南宁' );
$data []= array ( 'id' =>9, 'parentid' =>6, 'name' => '柳州' );
$data []= array ( 'id' =>10, 'parentid' =>2, 'name' => '纽约' );
$data []= array ( 'id' =>11, 'parentid' =>2, 'name' => '华盛顿' );
$data []= array ( 'id' =>12, 'parentid' =>3, 'name' => '首尔' );
$tree =build_tree( $data ,0);
//echo memory_get_usage();
print_r( $tree );
function findChild(& $arr , $id ){
$childs = array ();
foreach ( $arr as $k => $v ){
if ( $v [ 'parentid' ]== $id ){
$childs []= $v ;
}
}
return $childs ;
}
function build_tree( $rows , $root_id ){
$childs =findChild( $rows , $root_id );
if ( empty ( $childs )){
return null;
}
foreach ( $childs as $k => $v ){
$rescurTree =build_tree( $rows , $v [ 'id' ]);
if ( null != $rescurTree ){
$childs [ $k ][ 'childs' ]= $rescurTree ;
}
}
return $childs ;
}
?>
|
运行结果:
?
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
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
|
Array
(
[0] => Array
(
[id] => 1
[parentid] => 0
[name] => 中国
[childs] => Array
(
[0] => Array
(
[id] => 4
[parentid] => 1
[name] => 北京
)
[1] => Array
(
[id] => 5
[parentid] => 1
[name] => 上海
)
[2] => Array
(
[id] => 6
[parentid] => 1
[name] => 广西
[childs] => Array
(
[0] => Array
(
[id] => 7
[parentid] => 6
[name] => 桂林
)
[1] => Array
(
[id] => 8
[parentid] => 6
[name] => 南宁
)
[2] => Array
(
[id] => 9
[parentid] => 6
[name] => 柳州
)
)
)
)
)
[1] => Array
(
[id] => 2
[parentid] => 0
[name] => 美国
[childs] => Array
(
[0] => Array
(
[id] => 10
[parentid] => 2
[name] => 纽约
)
[1] => Array
(
[id] => 11
[parentid] => 2
[name] => 华盛顿
)
)
)
[2] => Array
(
[id] => 3
[parentid] => 0
[name] => 韩国
[childs] => Array
(
[0] => Array
(
[id] => 12
[parentid] => 3
[name] => 首尔
)
)
)
)
|
希望本文所述对大家PHP程序设计有所帮助。
相关文章
猜你喜欢
- 个人服务器网站搭建:如何选择适合自己的建站程序或框架? 2025-06-10
- 64M VPS建站:能否支持高流量网站运行? 2025-06-10
- 64M VPS建站:怎样选择合适的域名和SSL证书? 2025-06-10
- 64M VPS建站:怎样优化以提高网站加载速度? 2025-06-10
- 64M VPS建站:是否适合初学者操作和管理? 2025-06-10
TA的动态
- 2025-07-10 怎样使用阿里云的安全工具进行服务器漏洞扫描和修复?
- 2025-07-10 怎样使用命令行工具优化Linux云服务器的Ping性能?
- 2025-07-10 怎样使用Xshell连接华为云服务器,实现高效远程管理?
- 2025-07-10 怎样利用云服务器D盘搭建稳定、高效的网站托管环境?
- 2025-07-10 怎样使用阿里云的安全组功能来增强服务器防火墙的安全性?
快网idc优惠网
QQ交流群
您的支持,是我们最大的动力!
热门文章
-
2025-06-04 40
-
CSS in JS 新秀:Vanilla-Extract 浅析
2025-05-29 31 -
2025-06-04 85
-
2025-05-29 25
-
2025-05-29 18
热门评论