PHP无限分类生成树方法,非递归,引用

 

  1. //这个是核心方法
  2. function generateTree($items){
  3.     $tree = array();
  4.     foreach($items as $item){
  5.         if(isset($items[$item['pid']])){
  6.             $items[$item['pid']]['son'][] =& $items[$item['id']];
  7.         }else{
  8.             $tree[] =& $items[$item['id']];
  9.         }
  10.     }
  11.     return $tree;
  12. }
  13. //这个是从发数据库中取出的数据
  14. $items = array(
  15.     1 => array('id' => 1, 'pid' => 0, 'name' => '安徽省'),
  16.     2 => array('id' => 2, 'pid' => 0, 'name' => '浙江省'),
  17.     3 => array('id' => 3, 'pid' => 1, 'name' => '合肥市'),
  18.     4 => array('id' => 4, 'pid' => 3, 'name' => '长丰县'),
  19.     5 => array('id' => 5, 'pid' => 1, 'name' => '安庆市'),
  20. );
  21. print_r(generateTree($items));

 

猜你喜欢

转载自www.cnblogs.com/Ares0023/p/9395450.html
今日推荐