У меня есть многомерный массив в PHP, созданный на замечательных примерах icio и ftrotter (я использую массив ftrotterrs в варианте с массивами):
Превратить результат базы данных в массив
Я сделал это в неупорядоченном списке шириной этого метода:
public function outputCategories($categories, $startingLevel = 0)
{
echo "<ul>\n";
foreach ($categories as $key => $category)
{
if (count($category['children']) > 0)
{
echo "<li>{$category['menu_nl']}\n";
$this->outputCategories($category['children'], $link
, $start, $startingLevel+1);
echo "</li>\n";
}
else
{
echo "<li>{$category['menu_nl']}</li>\n";
}
}
echo "</ul>\n";
}
Пока все хорошо.
Теперь я хочу использовать поле url_nl для создания URL, используемых в качестве ссылок в меню. URL должен отражать глубину ссылки в дереве, добавляя / url_nl для каждого шага вниз по дереву.
Моя цель:
- item 1 (has link: /item_1)
* subitem 1 (has link: /item_1/subitem_1)
* subitem 2 (has link: /item_1/subitem_1)
* subsubitem 1 (has link: /item_1/subitem_2/subsubitem_1)
- item 2 (has link: /item_2)
Стол
id
id1 (parent id)
menu_nl
url_nl
title_nl
etc
Что у меня так далеко:
public function outputCategories($categories, $link, $start, $startingLevel = 0)
{
// if start not exists
if(!$start)
$start = $startingLevel;
echo "<ul>\n";
foreach ($categories as $key => $category)
{
$link.= "/".$category['url_nl'];
if($start != $startingLevel)
$link = strrchr($link, '/');
if (count($category['children']) > 0)
{
echo "<li>".$start." - ".$startingLevel.
"<a href='$link'>{$category['menu_nl']}</a> ($link)\n";
$this->outputCategories($category['children'], $link
, $start, $startingLevel+1);
echo "</li>\n";
}
else
{
$start = $startingLevel+1;
echo "<li>".$start." - ".$startingLevel.
"<a href='$link'>{$category['menu_nl']}</a> ($link)</li>\n";
}
}
echo "</ul>\n";
}
Как вы видите в примере, я использовал поле url_nl, которое рекурсивно добавляется, поэтому каждый уровень списка имеет ссылку с путем, который используется в качестве URL.
Во всяком случае, у меня проблемы с созданием этих ссылок, так как они не сбрасываются должным образом при циклическом переходе к иерархическому списку. После перехода к ребенку в списке де первый прав, а второй нет.
Я застрял здесь ...