当前位置: 首页 > 编程笔记 >

PHP如何通过传引用的思想实现无限分类(代码简单)

竺翰海
2023-03-14
本文向大家介绍PHP如何通过传引用的思想实现无限分类(代码简单),包括了PHP如何通过传引用的思想实现无限分类(代码简单)的使用技巧和注意事项,需要的朋友参考一下

无限级分类,主要是通过储存上级分类的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运算与运算符