微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

PHPTree——php快速生成无限级分类

它就是PHPTree。

git地址:

或从编程之家下载

最简单的例子:

rush:PHP;"> //原始数据,从数据库读出
$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 字段来标识分类的层次:

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

输出为select标签

rush:PHP;"> echo '

PHPTree树形结构

'; echo '';

演示:

git中包含了一个输出HTML的demo,大家可以参考。

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

展开子节点:

true ));

输出的数据为:

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

自定义主键和父键:

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

输出的数据为:

[ { order_id:1, pid:0, ... } ]

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

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

'expanded','children_key' => 'children','leaf_key' => 'leaf' ));

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

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

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐