首頁 >php教程 >PHP源码 >巧妙使用php引用实现无限分类,输出层级数组,不用递归

巧妙使用php引用实现无限分类,输出层级数组,不用递归

PHP中文网
PHP中文网原創
2016-05-25 17:08:501187瀏覽

数据表字段,id,parentid。 
父分类parentid=0,子分类的parentid=父id。 

function getDataTree($rows, $id='id',$pid = 'parentid',$child = 'child',$root=0) {      $tree = array(); // 树  
        if(is_array($rows)){
             $array = array();
             foreach ($rows as $key=>$item){
             $array[$item[$id]] =& $rows[$key];
         }
         foreach($rows as $key=>$item){
             $parentId = $item[$pid];
             if($root == $parentId){
                 $tree[] =&$rows[$key];
             }else{
                 if(isset($array[$parentId])){
                     $parent =&$array[$parentId];
                     $parent[$child][]=&$rows[$key];
                 }
             }
         }
     }
     return $tree;
}
陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn