PHPTree——php快速生成無(wú)限級(jí)分類
它就是PHPTree。
git地址:https://git.oschina.net/jiusem/PHPTree.git
或從腳本之家下載 http://www.dbjr.com.cn/codes/606002.html
最簡(jiǎn)單的例子:
<?php require('PHPTree.class.php'); //原始數(shù)據(jù), 從數(shù)據(jù)庫(kù)讀出 $data = array( array( 'id'=>1, 'name'=>'book', 'parent_id'=>0 ), array( 'id'=>2, 'name'=>'music', 'parent_id'=>0 ), array( 'id'=>3, 'name'=>'book1', 'parent_id'=>1 ), array( 'id'=>4, 'name'=>'book2', 'parent_id'=>3 ) ); $r = PHPTree::makeTree($data); echo json_encode($r); ?>
輸出:
[
{
"id": 1,
"name": "book",
"parent_id": 0,
"expanded": false, //不展開(kāi)子節(jié)點(diǎn)
"children": [
{
"id": 3,
"name": "book1",
"parent_id": 1,
"expanded": false,
"children": [
{
"id": 4,
"name": "book2",
"parent_id": 3,
"leaf": true
}
]
}
]
},
{
"id": 2,
"name": "music",
"parent_id": 0,
"leaf": true
}
]
生成的數(shù)據(jù)就是樹(shù)形結(jié)構(gòu)了,可以結(jié)合ExtJS等前端框架來(lái)使用了。git中包含了一個(gè)ExtJS的demo,大家可以參考。
演示:
如果不需要使用前端框架,只是用HTML輸出,可以使用下面的方法:
$r = PHPTree::makeTreeForHtml($data);
得到一個(gè)一維數(shù)組,用 level 字段來(lái)標(biāo)識(shí)分類的層次:
array( array( 'id'=>1, 'name'=>'用戶管理', 'parent_id'=>0, 'level'=>0 //一級(jí)分類 ), array( 'id'=>1, 'name'=>'用戶列表', 'parent_id'=>1, 'level'=>1 //二級(jí)分類 ) .... );
輸出為select標(biāo)簽:
echo '<h1>PHPTree樹(shù)形結(jié)構(gòu)</h1>'; echo '<select style="width:300px;">'; foreach($r as $item){ echo '<option>'; //根據(jù)所在的層次縮進(jìn) echo str_repeat('......',$item['level']); echo $item['name']; echo '</option>'; } echo '</select>';
演示:
git中包含了一個(gè)輸出HTML的demo,大家可以參考。
關(guān)于數(shù)據(jù)庫(kù)的設(shè)計(jì),只需要保證包含 id 和 parent_id 字段即可,其他字段可以自行添加,不會(huì)影響數(shù)據(jù)生成。parent_id是父級(jí)ID,如果是一級(jí)分類,就設(shè)為 0 。當(dāng)然,字段也是可以配置的。請(qǐng)繼續(xù)往下看,我將介紹一些進(jìn)階的使用方法。
展開(kāi)子節(jié)點(diǎn):
PHPTree::makeTree( $data, array( 'expanded' => true ));
輸出的數(shù)據(jù)為:
[
{
id:1,
name:'book1',
expanded:true,//展開(kāi)子節(jié)點(diǎn)
children:[
...
]
}
]
自定義主鍵和父鍵:
//數(shù)據(jù)庫(kù)讀出 $data = array( array( 'order_id'=>1, //主鍵 'name'=>'book1', 'pid'=>0, //父鍵 ... ) ); PHPTree::makeTree( $data, array( 'primary_key' => 'order_id', 'parent_key' => 'pid' ));
輸出的數(shù)據(jù)為:
[
{
order_id:1,
name:'book1',
pid:0,
...
}
]
makeTreeForHtml 方法也支持配置主鍵和父鍵。
還有其他字段也可以自定義,但下面這些參數(shù)僅支持 makeTree 方法:
$r = PHPTree::makeTree($data, array( 'expanded_key' => 'expanded', 'children_key' => 'children', 'leaf_key' => 'leaf' ));
默認(rèn),這些字段的配置都是以ExtJS為參考的,如果你使用zTree框架的話,這些字段就需要重新配置了。
zTree 是一款強(qiáng)大的國(guó)產(chǎn)樹(shù)形框架,它還支持 簡(jiǎn)單JSON格式,是一維數(shù)據(jù)格式,實(shí)際上就不需要用到PHPTree了。當(dāng)然,PHPTree輸出的數(shù)據(jù)層次感清晰,zTree也是支持的。
- php實(shí)現(xiàn)無(wú)限級(jí)分類(遞歸方法)
- php 無(wú)限級(jí)分類,超級(jí)簡(jiǎn)單的無(wú)限級(jí)分類,支持輸出樹(shù)狀圖
- php實(shí)現(xiàn)無(wú)限級(jí)分類
- php實(shí)現(xiàn)無(wú)限級(jí)分類查詢(遞歸、非遞歸)
- ThinkPHP無(wú)限級(jí)分類原理實(shí)現(xiàn)留言與回復(fù)功能實(shí)例
- php+mysql實(shí)現(xiàn)無(wú)限級(jí)分類 | 樹(shù)型顯示分類關(guān)系
- ThinkPHP自動(dòng)填充實(shí)現(xiàn)無(wú)限級(jí)分類的方法
- php實(shí)現(xiàn)無(wú)限級(jí)分類實(shí)現(xiàn)代碼(遞歸方法)
- PHP實(shí)現(xiàn)遞歸無(wú)限級(jí)分類
- php 無(wú)限級(jí)分類學(xué)習(xí)參考之對(duì)ecshop無(wú)限級(jí)分類的解析 帶詳細(xì)注釋
相關(guān)文章
php實(shí)現(xiàn)異步將遠(yuǎn)程鏈接上內(nèi)容(圖片或內(nèi)容)寫(xiě)到本地的方法
這篇文章主要介紹了php實(shí)現(xiàn)異步將遠(yuǎn)程鏈接上內(nèi)容(圖片或內(nèi)容)寫(xiě)到本地的方法,涉及php基于curl進(jìn)行遠(yuǎn)程文件傳輸?shù)南嚓P(guān)操作技巧,需要的朋友可以參考下2016-11-11win7+apache+php+mysql環(huán)境配置操作詳解
本篇文章是對(duì)win7+apache+php+mysql環(huán)境配置的操作進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06如何直接訪問(wèn)php實(shí)例對(duì)象中的private屬性詳解
這篇文章主要給大家介紹了關(guān)于如何直接訪問(wèn)php實(shí)例對(duì)象中private屬性的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。2017-10-10修復(fù)ShopNC使用QQ 互聯(lián)時(shí)提示100010 錯(cuò)誤
本文給大家介紹了修復(fù)ShopNC使用QQ 互聯(lián)時(shí)提示100010 錯(cuò)誤的方法,以及QQ互聯(lián)里面的處理方法,有需要的小伙伴可以參考下2015-11-11