php無限級分類函式(無極限)
/** * [pidToGetTree description] * @Author Lerko * @DateTime 2017-04-05T10:44:06+0800 * @param [type] $list [所有的資料] * @param [type] &$data [返回的資料的載體,傳空陣列] * @param string $pk [預設主鍵] * @param string $pid [關聯到主鍵的key] * @param string $child_key [孩子節點的資料key] * @param string $sort_id [排序id] * @param [type] $sort_type [排序方式 php自身辯來給你 SORT_ASC SORT_DESC] * @return [type] [description] */function pidToGetTree($list,&$data,$pk='id',$pid='pid',$child_key="_child",$sort_id='sort_id',$sort_type=SORT_ASC,$start_pid=0){ if($data===null){ return; } if(count($data)==$start_pid){ //初始化根列表 foreach ($list as $key => &$value) { if($value[$pid]==0){ $data[]=$value; unset($list[$key]); } } $sort_root_arr=array_column($data,$sort_id); array_multisort($sort_root_arr,$sort_type,$data); } foreach ($data as $key => &$value) { foreach ($list as $key2 => $value2) { if($value2[$pid]==$value[$pk]){ $value[$child_key][]=$value2; unset($list[$key2]); } } if(empty($value[$child_key])){continue;} $sort_arr=array_column($value[$child_key],$sort_id); array_multisort($sort_arr,$sort_type,$value[$child_key]); pidToGetTree($list,$value[$child_key],$pk,$pid,$child_key,$sort_id,$sort_type); } }
輸入資料
+----+-----+---------+---------+---------+-------------+---------+| id | pid | root_id | user_id | sort_id | name_cn | name_en |+----+-----+---------+---------+---------+-------------+---------+| 1 | 0 | 2160 | 2160 | 0 | 種類1 | cat || 2 | 1 | 2160 | 2160 | 1 | 種類1-1 | cat || 3 | 1 | 2160 | 2160 | 1 | 種類1-2 | cat || 4 | 1 | 2160 | 2160 | 1 | 種類1-3 | cat || 5 | 0 | 2160 | 2160 | 0 | 種類5 | cat || 6 | 2 | 2160 | 2160 | 2 | 種類1-1-1 | cat || 7 | 5 | 2160 | 2160 | 5 | 種類5-1 | cat || 8 | 5 | 2160 | 2160 | 3 | 種類5-2 | cat || 9 | 0 | 2160 | 2160 | 0 | 種類9 | cat || 10 | 9 | 2160 | 2160 | 9 | 種類9-1 | cat || 11 | 9 | 2160 | 2160 | 9 | 種類9-2 | cat |+----+-----+---------+---------+---------+-------------+---------+
輸出資料
array (size=3) 0 => array (size=8) 'id' => string '1' (length=1) 'pid' => string '0' (length=1) 'root_id' => string '2160' (length=4) 'user_id' => string '2160' (length=4) 'sort_id' => string '0' (length=1) 'name_cn' => string '種類1' (length=7) 'name_en' => string 'cat' (length=3) '_child' => array (size=3) 0 => array (size=7) 'id' => string '2' (length=1) 'pid' => string '1' (length=1) 'root_id' => string '2160' (length=4) 'user_id' => string '2160' (length=4) 'sort_id' => string '1' (length=1) 'name_cn' => string '種類1-1' (length=9) 'name_en' => string 'cat' (length=3) 1 => array (size=7) 'id' => string '3' (length=1) 'pid' => string '1' (length=1) 'root_id' => string '2160' (length=4) 'user_id' => string '2160' (length=4) 'sort_id' => string '1' (length=1) 'name_cn' => string '種類1-2' (length=9) 'name_en' => string 'cat' (length=3) 2 => array (size=7) 'id' => string '4' (length=1) 'pid' => string '1' (length=1) 'root_id' => string '2160' (length=4) 'user_id' => string '2160' (length=4) 'sort_id' => string '1' (length=1) 'name_cn' => string '種類1-3' (length=9) 'name_en' => string 'cat' (length=3) 1 => array (size=8) 'id' => string '5' (length=1) 'pid' => string '0' (length=1) 'root_id' => string '2160' (length=4) 'user_id' => string '2160' (length=4) 'sort_id' => string '0' (length=1) 'name_cn' => string '種類5' (length=7) 'name_en' => string 'cat' (length=3) '_child' => array (size=2) 0 => array (size=7) 'id' => string '7' (length=1) 'pid' => string '5' (length=1) 'root_id' => string '2160' (length=4) 'user_id' => string '2160' (length=4) 'sort_id' => string '5' (length=1) 'name_cn' => string '種類5-1' (length=9) 'name_en' => string 'cat' (length=3) 1 => array (size=7) 'id' => string '8' (length=1) 'pid' => string '5' (length=1) 'root_id' => string '2160' (length=4) 'user_id' => string '2160' (length=4) 'sort_id' => string '3' (length=1) 'name_cn' => string '種類5-2' (length=9) 'name_en' => string 'cat' (length=3) 2 => array (size=8) 'id' => string '9' (length=1) 'pid' => string '0' (length=1) 'root_id' => string '2160' (length=4) 'user_id' => string '2160' (length=4) 'sort_id' => string '0' (length=1) 'name_cn' => string '種類9' (length=7) 'name_en' => string 'cat' (length=3) '_child' => array (size=2) 0 => array (size=7) 'id' => string '10' (length=2) 'pid' => string '9' (length=1) 'root_id' => string '2160' (length=4) 'user_id' => string '2160' (length=4) 'sort_id' => string '9' (length=1) 'name_cn' => string '種類9-1' (length=9) 'name_en' => string 'cat' (length=3) 1 => array (size=7) 'id' => string '11' (length=2) 'pid' => string '9' (length=1) 'root_id' => string '2160' (length=4) 'user_id' => string '2160' (length=4) 'sort_id' => string '9' (length=1) 'name_cn' => string '種類9-2' (length=9) 'name_en' => string 'cat' (length=3)
作者:lerko_
連結:
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/2001/viewspace-2803837/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- PHP實現無限極分類PHP
- php利用遞迴函式實現無限級分類PHP遞迴函式
- 分享一個無限極分類的函式函式
- PHP中的無限級分類、無限巢狀評論PHP巢狀
- PHP 無限級分類最佳實踐PHP
- php 無限分類遞迴 和 無限分類引入 的效能差距PHP遞迴
- PHP 快速掃描列表建立無限極分類樹PHP
- Laravel 框架實現無限極分類Laravel框架
- 選單的無限極分類實現
- 不用遞推實現無限極分類
- mysql 無限級分類實現思路MySql
- PHP無限級分類的實現(不使用遞迴)PHP遞迴
- laravel模型無限分類Laravel模型
- 無限分級 方法總結
- 高效能無限級分類實現思路
- 無限級分類---有關查詢問題??
- PHP + MySQL 無限分類實現的2種方法PHPMySql
- Javascript無限分類演算法(轉)JavaScript演算法
- 分層資料 Hierarchical Data 探索 (1.遞迴) 無限極分類遞迴
- FreeSql 使用 ToTreeList/AsTreeCte 查詢無限級分類表SQLAST
- 哪位大師能用匿名遞迴下這個無限極分類?遞迴
- PHP無限級評論回覆功能實現PHP
- 後端返回無限極陣列後, 前端進行無限極渲染 , 菜鳥篇後端陣列前端
- 使用遞迴實現樹狀選單(無限級分類)遞迴
- thinkphp5資料的無限分類PHP
- 分層資料 Hierarchical Data 探索 (2.鄰接表模型) 無限極分類模型
- 分層資料 Hierarchical Data 探索 (3.巢狀集合模型) 無限極分類巢狀模型
- Ztree + PHP 無限級節點遞迴查詢PHP遞迴
- 無限級分類之Laravel-nestedset擴充套件包的使用Laravel套件
- mysql count函式與分頁功能極限優化MySql函式優化
- 分享一個用 ORM 寫無限極分類的帖子, 大佬請跳過.ORM
- mysql count函式與分頁功能極限最佳化MySql函式
- [推薦]無限分級數量查詢優化優化
- 15.3 極限函式與和函式性質函式
- 小程式無限層級路由方案路由
- js函式add(1)(2)(3)(4)...實現無限極累加原理解析JS函式
- [Dcat Admin]表單無限極select
- 無限踩坑