在多维PHP数组中递归以生成HTML列表


Recurse through a multi-dimensional PHP array to produce a HTML list

遗憾的是,我很难处理任何涉及递归的问题,这个问题也没什么不同。

我在PHP数组中有一个类别结构。我已经按照这样的父类别对其进行了分组,但如果有解决方案保证,我很乐意更改:

array(5) {
  [0] => array(4) {
    [50] => array(5) {
      ["category_id"] => int(50)
      ["category_title"] => string(29) "Category 50"
      ["parent_category_id"] => int(0)
      ["display_order"] => int(0)
      ["depth"] => int(0)
    }
    [1] => array(5) {
      ["category_id"] => int(1)
      ["category_title"] => string(24) "Category 1"
      ["parent_category_id"] => int(0)
      ["display_order"] => int(1)
      ["depth"] => int(0)
    }
    [80] => array(5) {
      ["category_id"] => int(80)
      ["category_title"] => string(27) "Category 80"
      ["parent_category_id"] => int(0)
      ["display_order"] => int(1)
      ["depth"] => int(0)
    }
    [10] => array(5) {
      ["category_id"] => int(10)
      ["category_title"] => string(29) "Category 10"
      ["parent_category_id"] => int(0)
      ["display_order"] => int(10)
      ["depth"] => int(0)
    }
  }
  [1] => array(1) {
    [2] => array(5) {
      ["category_id"] => int(2)
      ["category_title"] => string(21) "Category 2"
      ["parent_category_id"] => int(1)
      ["display_order"] => int(1)
      ["depth"] => int(1)
    }
  }
  [30] => array(1) {
    [90] => array(5) {
      ["category_id"] => int(90)
      ["category_title"] => string(11) "Category 90"
      ["parent_category_id"] => int(30)
      ["display_order"] => int(1)
      ["depth"] => int(2)
    }
  }
  [10] => array(2) {
    [20] => array(5) {
      ["category_id"] => int(20)
      ["category_title"] => string(21) "Category 20"
      ["parent_category_id"] => int(10)
      ["display_order"] => int(10)
      ["depth"] => int(1)
    }
    [30] => array(5) {
      ["category_id"] => int(30)
      ["category_title"] => string(17) "Category 30"
      ["parent_category_id"] => int(10)
      ["display_order"] => int(20)
      ["depth"] => int(1)
    }
  }
  [50] => array(3) {
    [40] => array(5) {
      ["category_id"] => int(40)
      ["category_title"] => string(6) "Category 40"
      ["parent_category_id"] => int(50)
      ["display_order"] => int(1000)
      ["depth"] => int(1)
    }
    [60] => array(5) {
      ["category_id"] => int(60)
      ["category_title"] => string(6) "Category 60"
      ["parent_category_id"] => int(50)
      ["display_order"] => int(2000)
      ["depth"] => int(1)
    }
    [70] => array(5) {
      ["category_id"] => int(70)
      ["category_title"] => string(17) "Category 70"
      ["parent_category_id"] => int(50)
      ["display_order"] => int(3000)
      ["depth"] => int(1)
    }
}

因此HTML的最终结果应该是这样的:

<ul>
    <li>Category 50</li>
    <ul>
        <li>Category 40</li>
        <li>Category 60</li>
        <li>Category 70</li>
    </ul>
    <li>Category 1</li>
    <ul>
        <li>Category 2</li>
    </ul>
    <li>Category 80</li>
    <li>Category 10</li>
    <ul>
        <li>Category 20</li>
        <li>Category 30</li>
        <ul>
            <li>Category 90</li>
        </ul>
    </ul>
</ul>

请注意,可能存在多个级别的嵌套。

尽管在上面的例子中没有描述,但能够为每个列表项使用不仅仅是"category_title"(还有一些其他参数没有显示,例如,为了简单起见,已经删除了计数和其他统计数据)将是有用的。

我非常感激你读到这篇文章。如有任何建议,不胜感激。

最终结果的可视化表示HTML:

我想把它转换成这样的HTML列表:

  • 第50类
    • 第40类
    • 第60类 >第70类 1
  • 第1类
  • 2
  • 第80类
  • 30 <10
      第20类
    • 30类
      第90类

      这应该可以工作。请注意,这是一个未经测试的脚本:

      function recursiveList($array) {
         echo '<ul>';
         foreach ($array as $key => $value) {
             if (is_array($value) && !isset($value['category_id'])) { // if isset fails means that there is an array containing other categories arrays
                 recursiveList($value);
             }
             echo '<li>' . $value['category_title'] . '</li>';
         }
         echo '</ul>';
      }
      recursiveList($categories);