Thinkphp框架使用list_to_tree 實(shí)現(xiàn)無(wú)限級(jí)分類(lèi)列出所有節(jié)點(diǎn)示例
本文實(shí)例講述了Thinkphp框架使用list_to_tree 實(shí)現(xiàn)無(wú)限級(jí)分類(lèi)列出所有節(jié)點(diǎn)。分享給大家供大家參考,具體如下:
list_to_tree 使用起來(lái)十分方便,詳細(xì)可查看手冊(cè)。因?yàn)槲以谟玫臅r(shí)候需要同時(shí)列出所有節(jié)點(diǎn),所以寫(xiě)了一個(gè)遞歸函數(shù),拿出來(lái)供大家參考。
public function index(){
Load('extend'); //加載擴(kuò)展方法
$Category=D('Category');
$list=$Category->order('sort desc')->select();//實(shí)現(xiàn)同級(jí)節(jié)點(diǎn)排序
$list=list_to_tree($list,'id','fid'); //詳細(xì)參數(shù)見(jiàn)手冊(cè)
$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;
}
/**
* 把返回的數(shù)據(jù)集轉(zhuǎn)換成Tree
* @access public
* @param array $list 要轉(zhuǎn)換的數(shù)據(jù)集
* @param string $pid parent標(biāo)記字段
* @param string $level level標(biāo)記字段
* @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)建基于主鍵的數(shù)組引用
$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;
}
/**
* 對(duì)查詢結(jié)果集進(jìn)行排序
* @access public
* @param array $list 查詢結(jié)果
* @param string $field 排序的字段名
* @param array $sortby 排序類(lèi)型
* 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;
}
/**
* 在數(shù)據(jù)列表中搜索
* @access public
* @param array $list 數(shù)據(jù)列表
* @param mixed $condition 查詢條件
* 支持 array('name'=>$value) 或者 name=$value
* @return array
*/
function list_search($list,$condition) {
if(is_string($condition))
parse_str($condition,$condition);
// 返回的結(jié)果集合
$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;
}
更多關(guān)于thinkPHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《ThinkPHP入門(mén)教程》、《thinkPHP模板操作技巧總結(jié)》、《ThinkPHP常用方法總結(jié)》、《codeigniter入門(mén)教程》、《CI(CodeIgniter)框架進(jìn)階教程》、《Zend FrameWork框架入門(mén)教程》及《PHP模板技術(shù)總結(jié)》。
希望本文所述對(duì)大家基于ThinkPHP框架的PHP程序設(shè)計(jì)有所幫助。
- thinkphp5實(shí)現(xiàn)無(wú)限級(jí)分類(lèi)
- 使用ThinkPHP的自動(dòng)完成實(shí)現(xiàn)無(wú)限級(jí)分類(lèi)實(shí)例詳解
- Thinkphp無(wú)限級(jí)分類(lèi)代碼
- ThinkPHP無(wú)限級(jí)分類(lèi)原理實(shí)現(xiàn)留言與回復(fù)功能實(shí)例
- ThinkPHP自動(dòng)填充實(shí)現(xiàn)無(wú)限級(jí)分類(lèi)的方法
- thinkphp框架無(wú)限級(jí)欄目的排序功能實(shí)現(xiàn)方法示例
- thinkPHP實(shí)現(xiàn)遞歸循環(huán)欄目并按照樹(shù)形結(jié)構(gòu)無(wú)限極輸出的方法
- thinkphp實(shí)現(xiàn)無(wú)限分類(lèi)(使用遞歸)
- ThinkPHP實(shí)現(xiàn)遞歸無(wú)級(jí)分類(lèi)——代碼少
相關(guān)文章
ThinkPHP5框架實(shí)現(xiàn)簡(jiǎn)單的批量查詢功能示例
這篇文章主要介紹了ThinkPHP5框架實(shí)現(xiàn)簡(jiǎn)單的批量查詢功能,結(jié)合實(shí)例形式分析了thinkPHP5框架使用原生SQL語(yǔ)句查詢、批量查詢、快速查詢、聚合查詢等操作實(shí)現(xiàn)技巧,需要的朋友可以參考下2018-06-06
thinkphp5.1驗(yàn)證碼及驗(yàn)證碼驗(yàn)證功能的實(shí)現(xiàn)詳解
這篇文章主要介紹了thinkphp5.1驗(yàn)證碼及驗(yàn)證碼驗(yàn)證功能的實(shí)現(xiàn)詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-01-01
php在windows環(huán)境下獲得cpu內(nèi)存實(shí)時(shí)使用率(推薦)
這篇文章主要介紹了php在windows環(huán)境下獲得 cpu 內(nèi)存實(shí)時(shí)使用率的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2018-02-02
php 廣告點(diǎn)擊統(tǒng)計(jì)代碼(php+mysql)
本文講的是php 廣告點(diǎn)擊統(tǒng)計(jì)代碼, php 廣告點(diǎn)擊統(tǒng)計(jì)代碼,昨天晚上有幾個(gè)IDC網(wǎng)想與本站合作放些廣告,但是我想看看廣告效果后想了就寫(xiě)了一個(gè)簡(jiǎn)單的廣告統(tǒng)計(jì)代碼了,這里只是等的統(tǒng)計(jì)不能IP限制或是惡心點(diǎn)擊等等了2018-02-02
PHP開(kāi)發(fā)api接口安全驗(yàn)證的實(shí)例講解
下面小編就為大家分享一篇PHP開(kāi)發(fā)api接口安全驗(yàn)證的實(shí)例講解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-03-03
Laravel Memcached緩存驅(qū)動(dòng)的配置與應(yīng)用方法分析
這篇文章主要介紹了Laravel Memcached緩存驅(qū)動(dòng)的配置與應(yīng)用方法,結(jié)合實(shí)例形式分析了在Laravel框架配置Memcached緩存及相關(guān)使用方法,需要的朋友可以參考下2016-10-10

