下面是一个处理无限层级分类的PHP递归函数示例:
function getCategoryTree($categories, $parent_id = 0) {
$tree = array();
foreach ($categories as $category) {
if ($category['parent_id'] == $parent_id) {
$children = getCategoryTree($categories, $category['id']);
if ($children) {
$category['children'] = $children;
}
$tree[] = $category;
}
}
return $tree;
}
// 示例数据
$categories = array(
array('id' => 1, 'name' => 'Category 1', 'parent_id' => 0),
array('id' => 2, 'name' => 'Category 2', 'parent_id' => 0),
array('id' => 3, 'name' => 'Category 1.1', 'parent_id' => 1),
array('id' => 4, 'name' => 'Category 1.2', 'parent_id' => 1),
array('id' => 5, 'name' => 'Category 1.1.1', 'parent_id' => 3),
);
$tree = getCategoryTree($categories);
print_r($tree);
在上面的例子中,getCategoryTree
函数接受一个包含所有分类的数组和一个父分类ID作为参数,并递归地构建一个树形结构的数组。通过调用getCategoryTree
函数并传入示例数据后,将会输出一个包含层级关系的分类树。您可以根据实际需求修改示例数据和函数逻辑。