首頁 >後端開發 >php教程 >php怎麼快速產生無限級分類(附程式碼)

php怎麼快速產生無限級分類(附程式碼)

php中世界最好的语言
php中世界最好的语言原創
2018-05-17 11:58:061595瀏覽

這次帶給大家php怎麼快速產生無限級分類(附程式碼),php快速產生無限級分類的注意事項有哪些,下面就是實戰案例,一起來看一下。

最簡單的例子:

<?php 
require(&#39;PHPTree.class.php&#39;);
//原始数据, 从数据库读出
$data = array(
	array(
		&#39;id&#39;=>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);
?>

輸出:

  [
        {
          "book",
            "parent_id": 0,
            "exp            {
                    "id": 3,
                    "name": "book1",
                    "parent_id": 1,
                    "expanded": false,
                    "children": [
                        {
                            "id": 4,
                            "name": "book2",
   ent_id": 3,
                        的}                    ]
               #        {
            "id": 2,
#                   "leaf": true
        }
]


產生的資料就是樹狀結構了,可以結合ExtJS等前端框架來使用了。 git包含了一個ExtJS的demo,大家可以參考。

示範:




如果不需要使用前端框架,只是用HTML輸出,可以使用下面的方法:

# $r = PHPTree::makeTreeForHtml($data);

得到一個

一維數組,用level 欄位來識別分類的層次:

array(
 array(
  'id'=>1,
  'name'=>'用户管理',
  'parent_id'=>0,
  'level'=>0 //一级分类
 ),
 array(
  'id'=>1,
  'name'=>'用户列表',
  'parent_id'=>1,
  'level'=>1 //二级分类
 )
 ....
);

輸出為select標籤:

echo '<h1>PHPTree树形结构</h1>';
echo '<select style="width:300px;">';
foreach($r as $item){
	echo '<option>';
	//根据所在的层次缩进
	echo str_repeat('......',$item['level']);
	echo $item['name'];
	echo '</option>';
}
echo '</select>';
示範:

#git中包含了一個輸出HTML的demo,大家可以參考。

关于数据库的设计,只需要保证包含 id 和 parent_id 字段即可,其他字段可以自行添加,不会影响数据生成。parent_id是父级ID,如果是一级分类,就设为 0 。当然,字段也是可以配置的。请继续往下看,我将介绍一些进阶的使用方法。

展开子节点:

PHPTree::makeTree( $data, array(
 'expanded' => true
));

输出的数据为:

[
        {
            id:1,
            name:'book1',
            expanded:true,//展开子节点
            children:[
                ...
            ]
        }
]

自定义主键和父键:

//数据库读出
$data = array(
 array(
  'order_id'=>1, //主键
  'name'=>'book1',
  'pid'=>0, //父键
  ...
 )
);
PHPTree::makeTree( $data, array(
 'primary_key' => 'order_id',
 'parent_key' => 'pid'
));

输出的数据为:

[
        {
            order_id:1,
            name:'book1',
            pid:0,
            ...
        }
]

makeTreeForHtml 方法也支持配置主键和父键。

还有其他字段也可以自定义,但下面这些参数仅支持 makeTree 方法:

$r = PHPTree::makeTree($data, array(
 'expanded_key' => 'expanded',
 'children_key' => 'children',
 'leaf_key'  => 'leaf'
));

默认,这些字段的配置都是以ExtJS为参考的,如果你使用zTree框架的话,这些字段就需要重新配置了。

zTree 是一款强大的国产树形框架,它还支持 简单JSON格式,是一维数据格式,实际上就不需要用到PHPTree了。当然,PHPTree输出的数据层次感清晰,zTree也是支持的。

相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!

推荐阅读:

PHP动态获取函数参数步骤详解

PHP原型模式案例解析

以上是php怎麼快速產生無限級分類(附程式碼)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn