无限级分类,主要是通过储存上级分类的id以及分类路径来实现
在我的Simpla中,用到了无限分类,使用了PHP的传引用思想实现无限分类的方法,可以完美展示类似这样的分类模式。
id pid name
1 0 四川
2 0 重庆
3 1 成都
4 1 绵阳
5 3 高新区
代码如下所示:
/** * 数组变成无限级分类--传引用思想 * @param array $items * @return array */ public static function get_tree($orig) { //解决下标不是1开始的问题 $items = array(); foreach ($orig as $key => $value) { $items[$value[‘id‘]] = $value; } //开始组装 $tree = array(); foreach ($items as $key => $item) { if ($item[‘pid‘] == 0) { //为0,则为1级分类 $tree[] = &$items[$key]; } else { if (isset($items[$item[‘pid‘]])) { //存在值则为二级分类 $items[$item[‘pid‘]][‘child‘][] = &$items[$key]; //传引用直接赋值与改变 } else { //至少三级分类 //由于是传引用思想,这里将不会有值 $tree[] = &$items[$key]; } } } return $tree; }
以上内容很简单吧,如有错误或者更好的方法,希望可以相互交流。谢谢。!
本文向大家介绍php实现无限级分类,包括了php实现无限级分类的使用技巧和注意事项,需要的朋友参考一下 1.递归,查找子孙树 2.递归,求家谱树 家谱树的应用 ,如面包屑导航 首页 > 手机类型 > CDMA手机 > 公益PHP > 递归应用 2.迭代,求家谱树
本文向大家介绍php通过前序遍历树实现无需递归的无限极分类,包括了php通过前序遍历树实现无需递归的无限极分类的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了php通过前序遍历树实现无需递归的无限极分类。分享给大家供大家参考。具体如下: 大家通常都是使用递归实现无限极分类都知道递归效率很低,下面介绍一种改进的前序遍历树算法,不适用递归实现无限极分类,在大数据量实现树状层级结构的时候效率更高
本文向大家介绍PHP实现递归无限级分类,包括了PHP实现递归无限级分类的使用技巧和注意事项,需要的朋友参考一下 在一些复杂的系统中,要求对信息栏目进行无限级的分类,以增强系统的灵活性。那么PHP是如何实现无限级分类的呢?我们在本文中使用递归算法并结合mysql数据表实现无限级分类。 递归,简单的说就是一段程序代码的重复调用,当把代码写到一个自定义函数中,将参数等变量保存,函数中重复调用函数,直到达
本文向大家介绍PHP实现简单实用的验证码类,包括了PHP实现简单实用的验证码类的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了PHP实现简单实用的验证码类。分享给大家供大家参考。具体如下: 希望本文所述对大家的php程序设计有所帮助。
本文向大家介绍简单的pgsql pdo php操作类实现代码,包括了简单的pgsql pdo php操作类实现代码的使用技巧和注意事项,需要的朋友参考一下 核心代码:
本文向大家介绍php无限级分类实现方法分析,包括了php无限级分类实现方法分析的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了php无限级分类实现方法。分享给大家供大家参考,具体如下: 1. 递归 2. 普通 更多关于PHP相关内容感兴趣的读者可查看本站专题:《php字符串(string)用法总结》、《PHP数组(Array)操作技巧大全》、《PHP基本语法入门教程》、《PHP运算与运算符