PHP递归遍历多维数组实现无限分类的方法

2025-05-29 0 98

本文实例讲述了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程序设计有所帮助。

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

快网idc优惠网 建站教程 PHP递归遍历多维数组实现无限分类的方法 https://www.kuaiidc.com/98549.html

相关文章

发表评论
暂无评论