php mysql 无限分类_php三种无限分类

无限分类,是指从一个最高分类开始,每个子分类都可以分出自己的若干个子分类,可以一直分下去,称为无限级分类;

下面是对省市县的无限极分类的列子。数据库如图:

代码示例如下:

/**

* @Description: 无限极分类一

* @Author: Yang

* @param $data 数据库数据

* @param int $parent_id 父级ID

* @return array

*/

function getTree1($data, $parent_id = 0)

{

$tree = array();

foreach ($data as $k => $v) {

if ($v["parent_id"] == $parent_id) {

unset($data[$k]);

if (!empty($data)) {

$children = getTree1($data, $v["id"]);

if (!empty($children)) {

$v["_child"] = $children;

}

}

$tree[] = $v;

}

}

return $tree;

}

/**

* @Description: 无限极分类二

* @Author: Yang

* @param $data 数据库数据

* @param int $parent_id 父级ID

* @param int $level 等级

* @return array

*/

function getTree2($data, $parent_id = 0, $level = 0)

{

static $tree = array();

foreach ($data as $k => $v) {

if ($v["parent_id"] == $parent_id) {

$v["level"] = $level;

$tree[] = $v;

getTree2($data, $v["id"], $level + 1);

}

}

return $tree;

}

/**

* @Description: 无限分类三:面包屑导航

* @Author: Yang

* @param $data 数据库数据

* @param $id 分类ID

* @return array

*/

function getCrumbsBar($data, $id) {

static $tree = array();

foreach ($data as $k => $v) {

if ($v["id"] == $id) {

getCrumbsBar($data, $v["parent_id"]);

$tree[] = $v;

}

}

return $tree;

}

以上内容希望帮助到大家,很多PHPer在进阶的时候总会遇到一些问题和瓶颈,业务代码写多了没有方向感,不知道该从那里入手去提升,对此我整理了一些资料,包括但不限于:分布式架构、高可扩展、高性能、高并发、服务器性能调优、TP6,laravel,YII2,Redis,Swoole、Swoft、Kafka、Mysql优化、shell脚本、Docker、微服务、Nginx等多个知识点高级进阶干货需要的可以免费分享给大家,需要PHP进阶架构师>>>视频、面试文档免费获取​docs.qq.com2547dabdcd1101902b4b00ccf2d41dbb.png

或 者关注咱们下面的知乎专栏PHP大神进阶​zhuanlan.zhihu.com9ba67966a1b0bb55561d61228e326664.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值