在 PHP 中实现无限极分类通常需要使用递归函数来处理。下面是一个简单的示例代码,演示了如何实现无限极分类:
<?php
// 假设有一个无限极分类的数据数组
$categories = [
['id' => 1, 'name' => '分类1', 'parent_id' => 0],
['id' => 2, 'name' => '分类2', 'parent_id' => 0],
['id' => 3, 'name' => '分类1.1', 'parent_id' => 1],
['id' => 4, 'name' => '分类1.2', 'parent_id' => 1],
['id' => 5, 'name' => '分类2.1', 'parent_id' => 2],
['id' => 6, 'name' => '分类1.1.1', 'parent_id' => 3],
];
// 构建分类树
function buildCategoryTree($categories, $parent_id = 0)
{
$tree = [];
foreach ($categories as $category) {
if ($category['parent_id'] == $parent_id) {
$children = buildCategoryTree($categories, $category['id']);
if ($children) {
$category['children'] = $children;
}
$tree[] = $category;
}
}
return $tree;
}
// 输出分类树
$categoryTree = buildCategoryTree($categories);
print_r($categoryTree);
?>
在上面的示例中,我们首先定义了一个包含无限极分类数据的数组 $categories
。每个分类都有一个 id
表示唯一标识,name
表示分类名称,parent_id
表示父级分类的 ID。
然后,我们定义了一个名为 buildCategoryTree
的递归函数来构建分类树。该函数接受两个参数:$categories
分类数组和 $parent_id
父级分类 ID。函数首先创建一个空数组 $tree
用于存储分类树。然后,遍历 $categories
数组,找到所有父级 ID 为 $parent_id
的分类,并将它们添加到 $tree
中。对于每个这样的分类,如果它有子分类,则递归调用 buildCategoryTree
函数来构建子分类树,并将其存储在分类数组中的 children
键中。最后,返回分类树数组 $tree
。
最后,我们调用 buildCategoryTree
函数来构建分类树,并将其存储在变量 $categoryTree
中。然后使用 print_r
函数将其打印出来,以展示分类树的结构。
请注意,上述示例仅提供了一个基本的框架来演示如何实现无限极分类。实际应用中,你可能需要根据自己的需求进行适当的修改和扩展。