PHP递归遍历多维数组实现无限分类的方法
来源: 阅读:954 次 日期:2016-08-24 15:09:56
温馨提示: 小编为您整理了“PHP递归遍历多维数组实现无限分类的方法”,方便广大网友查阅!

本文实例讲述了PHP递归遍历多维数组实现无限分类的方法。分享给大家供大家参考,具体如下:

<?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;

 }

?>

运行结果:

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程序设计有所帮助。

更多信息请查看网络编程
由于各方面情况的不断调整与变化, 提供的所有考试信息和咨询回复仅供参考,敬请考生以权威部门公布的正式信息和咨询为准!
关于我们 | 联系我们 | 人才招聘 | 网站声明 | 网站帮助 | 非正式的简要咨询 | 简要咨询须知 | 加入群交流 | 手机站点 | 投诉建议
工业和信息化部备案号:滇ICP备2023014141号-1 云南省教育厅备案号:云教ICP备0901021 滇公网安备53010202001879号 人力资源服务许可证:(云)人服证字(2023)第0102001523号
云南网警备案专用图标
联系电话:0871-65317125(9:00—18:00) 获取招聘考试信息及咨询关注公众号:hfpxwx
咨询QQ:526150442(9:00—18:00)版权所有:
云南网警报警专用图标
Baidu
map