本文实例讲述了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
64
65
66
67
|
<?php
$rows = array (
array (
'id' => 1,
'name' => 'dev' ,
'parentid' => 0
),
array (
'id' => 2,
'name' => 'php' ,
'parentid' => 1
),
array (
'id' => 3,
'name' => 'smarty' ,
'parentid' => 2
),
array (
'id' => 4,
'name' => 'life' ,
'parentid' => 0
),
array (
'id' => 5,
'name' => 'pdo' ,
'parentid' => 2
),
array (
'id' => 6,
'name' => 'pdo-mysql' ,
'parentid' => 5
),
array (
'id' => 7,
'name' => 'java' ,
'parentid' => 1
)
);
// 72648
// 84072
function findChild(& $arr , $id ){
$childs = array ();
foreach ( $arr as $k => $v ){
if ( $v [ 'parentid' ]== $id ){
$childs []= $v ;
}
}
return $childs ;
}
function build_tree( $root_id ){
global $rows ;
$childs =findChild( $rows , $root_id );
if ( empty ( $childs )){
return null;
}
foreach ( $childs as $k => $v ){
$rescurTree =build_tree( $v [id]);
if ( null != $rescurTree ){
$childs [ $k ][ 'childs' ]= $rescurTree ;
}
}
return $childs ;
}
$tree =build_tree(0);
echo memory_get_usage();
print_r( $tree );
?>
|
希望本文所述对大家的php程序设计有所帮助。