遗憾的是,我很难处理任何涉及递归的问题,这个问题也没什么不同。
我在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
-
第20类
- 30类
这应该可以工作。请注意,这是一个未经测试的脚本:
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);