Меню навигации для зц

Печать RSS
259

Автор
Землянин
0
Нужно написать зц, появилась проблема
http://4mas.ru/download/?cat=8839 (не реклама)

интересует это:

Загрузки | Дизайны/CSS |
Простые/CSS-стили | Авторские Дизайны

с неограниченными категориями проблем нет, но вот как узнать путь , который прошел юзер, к примеру
/Загрузки/Музыка/Рок/и т.д.

Добавлено через 01:42 сек.
У таблицы такая структура,
id - ?!?
name - имя категории
pid - ид , в которой находится категория

Транклюкаторщик
0
Рекурсия.
while(родительская категория != "")
получаешь название и ид родительской категории.
формируешь строку
?????
Profit
С

Землянин
0
я раньше делал тоже через рекурсию. Ну вообще не так уж и хорошо, тем более для загруз центра. В последний раз, когда мне это понадобилось. Я отсортировал строки при запросе, результат запроса записал в двумерный массив и потом уже его мучил рекурсией.
С

Землянин
0
обращение функции к самой к себе.

function super () {

super();

}
Автор
Землянин
0
5. Voland, рекурсия! Спасибоsmile

2000 лет д.н.э.
0
Не надо запросы к бд в цикле делать.
По патчу одна выборка, в патч или весь путь до текущей папки, или все ид родительских деррикторий
Автор
Землянин
0
Еще вопрос, папки и файлы лучше хранить в одной таблице? Или

Лузер PHP
0
9. TRAIL, в разных(сортировку лучше делать в дальнейшем если потребуется) если смотреть со стороны ресурсов БД

Добавлено через 02:47 сек.
function menu_navigation($id_cat, $link, $cat)
  {
    $id_cat = intval($id_cat);
    $query = "SELECT * FROM $cat 
              WHERE id_cat = $id_cat";
    $cat = mysql_query($query);
    if(!$cat)
    {
      throw new ExceptionMySQL(mysql_error(), 
                               $query,
                              "Ошибка обращения к 
                               таблице каталога 
                               menu_navigation()");
    }
    if(mysql_num_rows($cat) > 0)
    {
      $cat_result = mysql_fetch_array($cat);
      $link = "<a class=menu 
              href=index.php?id_par=".$cat_result['id_cat'].">
              ".$cat_result['name']."</a>->".$link;
      $link = menu_navigation($cat_result['id_par'], 
                              $link, 
                              $cat);
    }
    return $link;
  }

А вот так бы я поступил по первому твоему вопросу
Б

Оранжевые штаны
0
7. Юзай лучше вложенные множества, если важно быстродействие при выборке
http://www.getinfo.ru/article610.html
С

Землянин
0
Интересная статья, взял на заметку. Но по-моему метод который я описал проще, может конечно не такой правильный, но удалять и добавлять категории гораздо удобнее.

Добавлено через 01:06 сек.
11. G_A_N_J_A_R, а ты этим пользуешься?
Стикеры / Теги / Правила / Топ тем / Топ постов / Поиск