这篇文章主要介绍了PHP无限极分类的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。
首先我们有一张栏目数据表 tree
表结构如下图(原文有图)
看上去表结构很简单。
我们插入几条测试数据
INSERT INTO `tree`
(`id`, `parent_id`, `name`)
VALUES
(1, 0, 'A'),
(2, 0, 'B'),
(3, 1, 'a'),
(4, 3, 'aa'),
(5, 2, 'b'),
(6, 4, 'aaa');
树形结构大致如下
|A
|--a
|----aa
|------aaa
|B
|--b
这也正是我们所需要的数据结构形式,下面我们来看看如何处理才能够得到所需要的结果。
我们前面也说了,以yii2为基础,因此我们的写法也按照面向对象的规则来
class tree {
//访问index查看树形结构
public function actionIndex () {
$data = self::getTree();
//为了方便测试,我们这里以json格式输出
\Yii::$app->response->format = \yii\web\Response::FORMAT_JSON;
return $data;
}
//获取树
public static function getTree () {
//这里我们直接获取所有的数据,然后通过程序进行处理
//在无限极分类中最忌讳的是对数据库进行层层操作,也就很容易造成内存溢出
//最后电脑死机的结果
$data = static::find()->all();
return self::_generateTree($data);
}
//生成树
private static function _generateTree ($data, $pid = 0) {
$tree = [];
if ($data && is_array($data)) {
foreach($data as $v) {
if($v['parent_id'] == $pid) {
$tree[] = [
'id' => $v['id'],
'name' => $v['name'],
'parent_id' => $v['parent_id'],
'children' => self::_generateTree($data, $v['id']),
];
}
}
}
return $tree;
}
}
我们访问下tree/index看看,效果图如下
这样我们可以看到一个很清晰的树形结构图,也就是我们最终所需要的。
感谢你能够认真阅读完这篇文章,希望小编分享的“PHP无限极分类的示例分析”这篇文章对大家有帮助,同时也希望大家多多支持亿速云,关注亿速云行业资讯频道,更多相关知识等着你来学习!
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。