它就是PHPTree。
最简单的例子:
$data = array(
array(
'id'=>1,'name'=>'book','parent_id'=>0
),array(
'id'=>2,'name'=>'music',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,//不展开子节点 "children": [ { "id": 3, "name": "book1", "parent_id": 1, "children": [ { "id": 4, "name": "book2", "parent_id": 3, "leaf": true } ] } ] }, { "id": 2, "name": "music", "leaf": true } ]
生成的数据就是树形结构了,可以结合ExtJS等前端框架来使用了。git中包含了一个ExtJS的demo,大家可以参考。
演示:
如果不需要使用前端框架,只是用HTML输出,可以使用下面的方法:
$r = PHPTree::makeTreeForHtml($data);
得到一个一维数组,用 level 字段来标识分类的层次:
PHPTree树形结构
'; echo '';演示:
git中包含了一个输出HTML的demo,大家可以参考。
关于数据库的设计,只需要保证包含 id 和 parent_id 字段即可,其他字段可以自行添加,不会影响数据生成。parent_id是父级ID,如果是一级分类,就设为 0 。当然,字段也是可以配置的。请继续往下看,我将介绍一些进阶的使用方法。
展开子节点:
输出的数据为:
[ { id:1, name:'book1', expanded:true,//展开子节点 children:[ ... ] } ]
自定义主键和父键:
输出的数据为:
[ { order_id:1, pid:0, ... } ]
还有其他字段也可以自定义,但下面这些参数仅支持 makeTree 方法:
默认,这些字段的配置都是以ExtJS为参考的,如果你使用zTree框架的话,这些字段就需要重新配置了。
zTree 是一款强大的国产树形框架,它还支持 简单JSON格式,是一维数据格式,实际上就不需要用到PHPTree了。当然,PHPTree输出的数据层次感清晰,zTree也是支持的。
原文链接:https://www.f2er.com/php/16184.html