Thinkphp框架使用list_to_tree 實現(xiàn)無限級分類列出所有節(jié)點示例
本文實例講述了Thinkphp框架使用list_to_tree 實現(xiàn)無限級分類列出所有節(jié)點。分享給大家供大家參考,具體如下:
list_to_tree 使用起來十分方便,詳細可查看手冊。因為我在用的時候需要同時列出所有節(jié)點,所以寫了一個遞歸函數,拿出來供大家參考。
public function index(){ Load('extend'); //加載擴展方法 $Category=D('Category'); $list=$Category->order('sort desc')->select();//實現(xiàn)同級節(jié)點排序 $list=list_to_tree($list,'id','fid'); //詳細參數見手冊 $list=$this->findChild($list); dump($list); } protected function findChild($arr){ static $tree=array(); foreach ($arr as $key=>$val){ $tree[]=$val; if (isset($val['_child'])){ $this->findChild($val['_child']); } } return $tree; }
/** * 把返回的數據集轉換成Tree * @access public * @param array $list 要轉換的數據集 * @param string $pid parent標記字段 * @param string $level level標記字段 * @return array */ function list_to_tree($list, $pk='id',$pid = 'pid',$child = '_child',$root=0) { // 創(chuàng)建Tree $tree = array(); if(is_array($list)) { // 創(chuàng)建基于主鍵的數組引用 $refer = array(); foreach ($list as $key => $data) { $refer[$data[$pk]] =& $list[$key]; } foreach ($list as $key => $data) { // 判斷是否存在parent $parentId = $data[$pid]; if ($root == $parentId) { $tree[] =& $list[$key]; }else{ if (isset($refer[$parentId])) { $parent =& $refer[$parentId]; $parent[$child][] =& $list[$key]; } } } } return $tree; } /** * 對查詢結果集進行排序 * @access public * @param array $list 查詢結果 * @param string $field 排序的字段名 * @param array $sortby 排序類型 * asc正向排序 desc逆向排序 nat自然排序 * @return array */ function list_sort_by($list,$field, $sortby='asc') { if(is_array($list)){ $refer = $resultSet = array(); foreach ($list as $i => $data) $refer[$i] = &$data[$field]; switch ($sortby) { case 'asc': // 正向排序 asort($refer); break; case 'desc':// 逆向排序 arsort($refer); break; case 'nat': // 自然排序 natcasesort($refer); break; } foreach ( $refer as $key=> $val) $resultSet[] = &$list[$key]; return $resultSet; } return false; } /** * 在數據列表中搜索 * @access public * @param array $list 數據列表 * @param mixed $condition 查詢條件 * 支持 array('name'=>$value) 或者 name=$value * @return array */ function list_search($list,$condition) { if(is_string($condition)) parse_str($condition,$condition); // 返回的結果集合 $resultSet = array(); foreach ($list as $key=>$data){ $find = false; foreach ($condition as $field=>$value){ if(isset($data[$field])) { if(0 === strpos($value,'/')) { $find = preg_match($value,$data[$field]); }elseif($data[$field]==$value){ $find = true; } } } if($find) $resultSet[] = &$list[$key]; } return $resultSet; }
更多關于thinkPHP相關內容感興趣的讀者可查看本站專題:《ThinkPHP入門教程》、《thinkPHP模板操作技巧總結》、《ThinkPHP常用方法總結》、《codeigniter入門教程》、《CI(CodeIgniter)框架進階教程》、《Zend FrameWork框架入門教程》及《PHP模板技術總結》。
希望本文所述對大家基于ThinkPHP框架的PHP程序設計有所幫助。
相關文章
ThinkPHP5框架實現(xiàn)簡單的批量查詢功能示例
這篇文章主要介紹了ThinkPHP5框架實現(xiàn)簡單的批量查詢功能,結合實例形式分析了thinkPHP5框架使用原生SQL語句查詢、批量查詢、快速查詢、聚合查詢等操作實現(xiàn)技巧,需要的朋友可以參考下2018-06-06thinkphp5.1驗證碼及驗證碼驗證功能的實現(xiàn)詳解
這篇文章主要介紹了thinkphp5.1驗證碼及驗證碼驗證功能的實現(xiàn)詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-01-01php在windows環(huán)境下獲得cpu內存實時使用率(推薦)
這篇文章主要介紹了php在windows環(huán)境下獲得 cpu 內存實時使用率的相關資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2018-02-02Laravel Memcached緩存驅動的配置與應用方法分析
這篇文章主要介紹了Laravel Memcached緩存驅動的配置與應用方法,結合實例形式分析了在Laravel框架配置Memcached緩存及相關使用方法,需要的朋友可以參考下2016-10-10