- 相關推薦
PHP無限分類(樹形類)的深入分析
文章是對PHP無限分類(樹形類)進行了詳細的分析介紹,需要的朋友參考下。就跟隨百分網小編一起去了解下吧,想了解更多相關信息請持續(xù)關注我們應屆畢業(yè)生考試網!
PHP無限分類,Google一下就能找到很多相關資料,思路比較拉風的,也是用得比較多的就是分類表至少有id,pid,name三個字段,id自增表分類,pid為父分類,name為分類名,這樣就構成了一棵樹,如下,算是我查詢分類表得到的結果集。
復制代碼 代碼如下:
<?php
//模擬PHP無限分類查詢結果
return array(
array(
'id'=>1,
'pid'=>0,
'name'=>'主頁'
),
array(
'id'=>2,
'pid'=>0,
'name'=>'新聞'
),
array(
'id'=>3,
'pid'=>0,
'name'=>'媒體'
),
array(
'id'=>4,
'pid'=>0,
'name'=>'下載'
),
array(
'id'=>5,
'pid'=>0,
'name'=>'關于我們'
),
array(
'id'=>6,
'pid'=>2,
'name'=>'天朝新聞'
),
array(
'id'=>7,
'pid'=>2,
'name'=>'海外新聞'
),
array(
'id'=>8,
'pid'=>6,
'name'=>'州官新聞'
),
array(
'id'=>9,
'pid'=>3,
'name'=>'音樂'
),
array(
'id'=>10,
'pid'=>3,
'name'=>'電影'
),
array(
'id'=>11,
'pid'=>3,
'name'=>'小說'
),
array(
'id'=>12,
'pid'=>9,
'name'=>'鈴聲'
),
array(
'id'=>13,
'pid'=>9,
'name'=>'流行音樂'
),
array(
'id'=>14,
'pid'=>9,
'name'=>'古典音樂'
),
array(
'id'=>15,
'pid'=>12,
'name'=>'熱門鈴聲'
),
array(
'id'=>16,
'pid'=>12,
'name'=>'搞笑鈴聲'
),
array(
'id'=>17,
'pid'=>12,
'name'=>'MP3鈴聲'
),
array(
'id'=>18,
'pid'=>17,
'name'=>'128K'
),
array(
'id'=>19,
'pid'=>8,
'name'=>'娛樂新聞'
),
array(
'id'=>20,
'pid'=>11,
'name'=>'穿越類'
),
array(
'id'=>21,
'pid'=>11,
'name'=>'武俠類'
),
);
?>
拉風歸拉風,但是那些文章提供的無限分類的類相關操作有點挫,直接把對數(shù)據(jù)庫操作也封裝進去了。也就是別人要用你這個類,還要跟你建一樣的表,真TM惡心。由于項目要用到,所以自己寫了一個PHP無限分類的類(也稱樹形類),沒有數(shù)據(jù)庫的操作,只需要實例化的時候傳進去結果集,也就是樹形數(shù)組。再執(zhí)行l(wèi)eaf方法或navi方法即可得到想要的結果,下面請看源碼,看完之后奉上smarty模板引擎的相應的模板遞歸方法。
復制代碼 代碼如下:
<?php
/**
* Tree 樹型類(無限分類)
*
* @author Kvoid
* @copyright http://kvoid.com
* @version 1.0
* @access public
* @example
* $tree= new Tree($result);
* $arr=$tree->leaf(0);
* $nav=$tree->navi(15);
*/
class Tree {
private $result;
private $tmp;
private $arr;
private $already = array();
/**
* 構造函數(shù)
*
* @param array $result 樹型數(shù)據(jù)表結果集
* @param array $fields 樹型數(shù)據(jù)表字段,array(分類id,父id)
* @param integer $root 頂級分類的父id
*/
public function __construct($result, $fields = array('id', 'pid'), $root = 0) {
$this->result = $result;
$this->fields = $fields;
$this->root = $root;
$this->handler();
}
/**
* 樹型數(shù)據(jù)表結果集處理
*/
private function handler() {
foreach ($this->result as $node) {
$tmp[$node[$this->fields[1]]][] = $node;
}
krsort($tmp);
for ($i = count($tmp); $i > 0; $i--) {
foreach ($tmp as $k => $v) {
if (!in_array($k, $this->already)) {
if (!$this->tmp) {
$this->tmp = array($k, $v);
$this->already[] = $k;
continue;
} else {
foreach ($v as $key => $value) {
if ($value[$this->fields[0]] == $this->tmp[0]) {
$tmp[$k][$key]['child'] = $this->tmp[1];
$this->tmp = array($k, $tmp[$k]);
}
}
}
}
}
$this->tmp = null;
}
$this->tmp = $tmp;
}
/**
* 反向遞歸
*/
private function recur_n($arr, $id) {
foreach ($arr as $v) {
if ($v[$this->fields[0]] == $id) {
$this->arr[] = $v;
if ($v[$this->fields[1]] != $this->root) $this->recur_n($arr, $v[$this->fields[1]]);
}
}
}
/**
* 正向遞歸
*/
private function recur_p($arr) {
foreach ($arr as $v) {
$this->arr[] = $v[$this->fields[0]];
if ($v['child']) $this->recur_p($v['child']);
}
}
/**
* 菜單 多維數(shù)組
*
* @param integer $id 分類id
* @return array 返回分支,默認返回整個樹
*/
public function leaf($id = null) {
$id = ($id == null) ? $this->root : $id;
return $this->tmp[$id];
}
/**
* 導航 一維數(shù)組
*
* @param integer $id 分類id
* @return array 返回單線分類直到頂級分類
*/
public function navi($id) {
$this->arr = null;
$this->recur_n($this->result, $id);
krsort($this->arr);
return $this->arr;
}
/**
* 散落 一維數(shù)組
*
* @param integer $id 分類id
* @return array 返回leaf下所有分類id
*/
public function leafid($id) {
$this->arr = null;
$this->arr[] = $id;
$this->recur_p($this->leaf($id));
return $this->arr;
}
}
?>
【PHP無限分類(樹形類)的深入分析】相關文章:
PHP學習:Category類庫無限分類07-28
php無限分類方法講解10-06
PHP的樹形結構算法07-06
php兩種無限分類方法實例06-15
php:樹形結構的算法實例10-18
PHP學習:PHP拼音類10-08
PHP應用:用XSLT輕松實現(xiàn)樹形折疊導航欄08-05
PHP類與構造函數(shù)07-01
PHP經典常用特效類代碼07-27