php生成無限欄目樹
更新時間:2017年03月16日 09:32:24 作者:雨落秋垣
本文主要介紹了php生成無限欄目樹的相關(guān)知識。具有很好的參考價值。下面跟著小編一起來看下吧
欄目數(shù)組:
$arr=Array( Array('cid' => 2,'cname' => '新聞','pid' => 0), Array('cid' => 4,'cname' =>'體育','pid' => 0), Array('cid' => 5,'cname' => '娛樂','pid' => 0), Array('cid' => 7,'cname' => '熱點新聞','pid' =>2), Array('cid' => 8,'cname' => '小眾新聞','pid' => 2), Array('cid' => 9,'cname' => '民謠新聞','pid' => 8), );
<?php $arr=Array( Array('cid' => 2,'cname' => '新聞','pid' => 0), Array('cid' => 4,'cname' =>'體育','pid' => 0), Array('cid' => 5,'cname' => '娛樂','pid' => 0), Array('cid' => 7,'cname' => '熱點新聞','pid' =>2), Array('cid' => 8,'cname' => '小眾新聞','pid' => 2), Array('cid' => 9,'cname' => '民謠新聞','pid' => 8), ); function formatTree($array, $pid = 0,$level = 1,$field = array('pid'=>'pid','id'=>'id','children'=>'children')){ $arr = array(); foreach ($array as &$v) { if ($v[$field['pid']] == $pid) { $v['level'] = $level; $tem = formatTree($array, $v[$field['id']],$v['level']+1,$field); //判斷是否存在子數(shù)組 $tem && $v[$field['children']] = $tem; $arr[] = $v; } } return $arr; } $tree = formatTree( $arr,0,1, $field = array('pid'=>'pid','id'=>'cid','children'=>'children') ); echo '<pre>'; print_r( $tree); ?>
我們有兩個方法來進行軟件設(shè)計:一個是讓其足夠的簡單以至于讓BUG無法藏身;另一個就是讓其足夠的復(fù)雜,讓人找不到BUG。前者更難一些。
以上就是本文的全部內(nèi)容,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,同時也希望多多支持腳本之家!
相關(guān)文章
php數(shù)組函數(shù)序列之in_array() 查找數(shù)組值是否存在
in_array() 函數(shù)在數(shù)組中搜索給定的值2011-10-10用PHP獲取Google AJAX Search API 數(shù)據(jù)的代碼
用PHP獲取Google AJAX Search API 數(shù)據(jù)的代碼2010-03-03PHP PDOStatement:bindParam插入數(shù)據(jù)錯誤問題分析
PHP PDOStatement:bindParam插入數(shù)據(jù)錯誤問題分析,開發(fā)中一定要注意2013-11-11