PHP遞歸遍歷多維數(shù)組實(shí)現(xiàn)無(wú)限分類(lèi)的方法
本文實(shí)例講述了PHP遞歸遍歷多維數(shù)組實(shí)現(xiàn)無(wú)限分類(lèi)的方法。分享給大家供大家參考,具體如下:
<?php //$data[]=array('id'=>1,'parentid'=>0,'name'=>'中國(guó)','img'=>'52091199'); $data[]=array('id'=>1,'parentid'=>0,'name'=>'中國(guó)'); $data[]=array('id'=>2,'parentid'=>0,'name'=>'美國(guó)'); $data[]=array('id'=>3,'parentid'=>0,'name'=>'韓國(guó)'); $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; } ?>
運(yùn)行結(jié)果:
Array ( [0] => Array ( [id] => 1 [parentid] => 0 [name] => 中國(guó) [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] => 美國(guó) [childs] => Array ( [0] => Array ( [id] => 10 [parentid] => 2 [name] => 紐約 ) [1] => Array ( [id] => 11 [parentid] => 2 [name] => 華盛頓 ) ) ) [2] => Array ( [id] => 3 [parentid] => 0 [name] => 韓國(guó) [childs] => Array ( [0] => Array ( [id] => 12 [parentid] => 3 [name] => 首爾 ) ) ) )
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專(zhuān)題:《PHP數(shù)組(Array)操作技巧大全》、《php排序算法總結(jié)》、《PHP常用遍歷算法與技巧總結(jié)》、《PHP數(shù)據(jù)結(jié)構(gòu)與算法教程》、《php程序設(shè)計(jì)算法總結(jié)》、《PHP數(shù)學(xué)運(yùn)算技巧總結(jié)》、《php正則表達(dá)式用法總結(jié)》、《PHP運(yùn)算與運(yùn)算符用法總結(jié)》、《php字符串(string)用法總結(jié)》及《php常見(jiàn)數(shù)據(jù)庫(kù)操作技巧匯總》
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。
- thinkphp實(shí)現(xiàn)無(wú)限分類(lèi)(使用遞歸)
- 解析thinkphp的左右值無(wú)限分類(lèi)
- PHP+Mysql樹(shù)型結(jié)構(gòu)(無(wú)限分類(lèi))數(shù)據(jù)庫(kù)設(shè)計(jì)的2種方式實(shí)例
- PHP無(wú)限分類(lèi)的類(lèi)
- PHP 無(wú)限分類(lèi)三種方式 非函數(shù)的遞歸調(diào)用!
- php遞歸方法實(shí)現(xiàn)無(wú)限分類(lèi)實(shí)例代碼
- php遞歸實(shí)現(xiàn)無(wú)限分類(lèi)生成下拉列表的函數(shù)
- 比較簡(jiǎn)單實(shí)用的PHP無(wú)限分類(lèi)源碼分享(思路不錯(cuò))
- PHP實(shí)現(xiàn)的無(wú)限分類(lèi)類(lèi)庫(kù)定義與用法示例【基于thinkPHP】
相關(guān)文章
php使用str_replace實(shí)現(xiàn)輸入框回車(chē)替換br的方法
這篇文章主要介紹了php使用str_replace實(shí)現(xiàn)輸入框回車(chē)替換br的方法,可實(shí)現(xiàn)使用\\n替換成br的方法,需要的朋友可以參考下2014-11-11PHP實(shí)現(xiàn)的簡(jiǎn)單四則運(yùn)算計(jì)算器功能示例
這篇文章主要介紹了PHP實(shí)現(xiàn)的簡(jiǎn)單四則運(yùn)算計(jì)算器功能,結(jié)合實(shí)例形式分析了PHP基于堆棧實(shí)現(xiàn)的表達(dá)式運(yùn)算功能,需要的朋友可以參考下2017-12-12PHP實(shí)現(xiàn)cookie跨域session共享的方法分析
這篇文章主要介紹了PHP實(shí)現(xiàn)cookie跨域session共享的方法,結(jié)合實(shí)例形式分析了php操作cookie的有效期、跨域、session存儲(chǔ)等相關(guān)操作技巧,需要的朋友可以參考下2019-08-08關(guān)于URL最大長(zhǎng)度限制的相關(guān)資料查證
這篇文章主要介紹了關(guān)于URL最大長(zhǎng)度限制的相關(guān)資料查證,這里記錄一下,方便以后使用。2014-12-12php在apache環(huán)境下實(shí)現(xiàn)gzip配置方法
這篇文章主要介紹了php在apache環(huán)境下實(shí)現(xiàn)gzip配置方法,較為詳細(xì)的分析了相關(guān)配置文件的修改技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2015-04-04php setcookie函數(shù)的參數(shù)說(shuō)明及其用法
這篇文章主要介紹了php setcookie函數(shù)的參數(shù)說(shuō)明及其用法,需要的朋友可以參考下2014-04-04PHP連接及操作PostgreSQL數(shù)據(jù)庫(kù)的方法詳解
這篇文章主要介紹了PHP連接及操作PostgreSQL數(shù)據(jù)庫(kù)的方法,結(jié)合實(shí)例形式分析了php針對(duì)PostgreSQL數(shù)據(jù)庫(kù)的基本連接以及增刪改查等相關(guān)操作技巧,需要的朋友可以參考下2019-01-01PHP實(shí)現(xiàn)的Redis操作通用類(lèi)示例
這篇文章主要介紹了PHP實(shí)現(xiàn)的Redis操作通用類(lèi),結(jié)合實(shí)例形式分析了php實(shí)現(xiàn)的redis連接、隊(duì)列、集合、hash表、事務(wù)等相關(guān)操作封裝技巧,需要的朋友可以參考下2018-06-06