С Новым годом! Форум программистов, компьютерный форум, киберфорум
PHP: базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.84/19: Рейтинг темы: голосов - 19, средняя оценка - 4.84
2 / 2 / 3
Регистрация: 11.09.2011
Сообщений: 557

Правильная организация древовидного меню

08.04.2014, 13:02. Показов 4168. Ответов 25
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте. Нужно организовать древовидное меню. Собственно говоря вот такого вида должна быть таблица:
Code
1
2
3
4
5
6
7
8
9
10
|id|Semestr|Predmet| Group |
| 1|    7  |   МО  | 7-78-5|
| 2|    7  |   МО  | 7-78-6|
| 3|    7  |   МО  | 7-78-7|
| 4|    8  |  ПР.Л | 8-78-5|
| 5|    8  |  ПР.Л | 8-78-6|
| 6|    8  |  ПР.Л | 8-78-7|
| 7|    3  | ПнаЯВУ| 3-78-5|
| 8|    3  | ПнаЯВУ| 3-78-6|
| 9|    3  | ПнаЯВУ| 3-78-7|
И вот так выводить все:
Сайт


Пока что получилось сделать только через parents
Через такую таблицу все удается сделать


НО, потом возникают проблему для условий изменения выборки главной таблицы (видно на первом скриншоте). Собственно по этому нужно сделать так, как написано в самом начале...

Добавлено через 5 минут
Вот так вывожу (это в случае с parents)
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
<?php
include ("bd.php");
 
function display_menus($parent = 0)
{
 $query = mysql_query("SELECT * FROM `menu` WHERE `parent` = '$parent' ORDER BY `title`") or die(mysql_error());
 if (mysql_num_rows($query) > 0)
 {
  echo "<ul>";
  while ($row = mysql_fetch_array($query))
  {
   echo "<li> <a href='index.php?menuitem=".$row['id']."&parents=".$row['parent']."&title=".$row['title']."'>" .$row['title']. "</a>";
   display_menus($row['title']);
   echo "</li>";
  }
  echo "</ul>";
 }
}
echo "Семестр";
display_menus();
 
?>
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
08.04.2014, 13:02
Ответы с готовыми решениями:

Правильная организация связанных таблиц
у меня есть 2 таблицы &quot;новости&quot; и &quot;категория&quot;, которые должны быть связаны. так вот я сначала просто сделал дополнительное поле в таблице...

Правильная организация базы данных
Добрый вечер уважаемый форум. Изучаю php путем создания своей небольшой игры. Сейчас добрался до момента который не могу разобрать. У...

Правильная организация изображений на проекте
Доброго времени суток! Вопрос одновременно касается как php так и mysql поэтому по логике разместил в это разделе надеюсь правильно. ...

25
2 / 2 / 3
Регистрация: 11.09.2011
Сообщений: 557
12.04.2014, 21:09  [ТС]
Студворк — интернет-сервис помощи студентам
Цитата Сообщение от fanatikus Посмотреть сообщение
как-то так
Выводит так:
Code
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
Семестры:
3
0
Warning: Invalid argument supplied for foreach() in  on line 109
 
7
0
Warning: Invalid argument supplied for foreach() in  on line 109
 
8
0
Warning: Invalid argument supplied for foreach() in  on line 109
 
1
Warning: Invalid argument supplied for foreach() in  on line 109
109-ая строчка: <?foreach($v1 as $k2 => $v2):?>

Добавлено через 13 минут
Сделал так:
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
<ul>
    <?foreach($semesters as $k => $v):?>
        <li><?=$k?></li>
        <ul>
            <?foreach($v as $k1 => $v1):?>
                <li><?=$v1?></li>
                <ul>
                    <?foreach($v1 as $k2 => $v2):?>
                        <li><?=$v2?></li>
                    <?endforeach?>
                </ul>
            <?endforeach?>
        </ul>
    <?endforeach?>
</ul>
Теперь выводит
Code
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
Семестры:
3
ПнаЯВУ
Warning: Invalid argument supplied for foreach() in  on line 109
 
7
МО
Warning: Invalid argument supplied for foreach() in  on line 109
 
8
АКиТП
Warning: Invalid argument supplied for foreach() in  on line 109
 
Пр.Л
Warning: Invalid argument supplied for foreach() in  on line 109
0
 Аватар для fanatikus
1932 / 1523 / 703
Регистрация: 17.11.2012
Сообщений: 6,585
12.04.2014, 21:17
я не экстрасенс, не понимаю что там у вас не получается.
у меня все работает, проверил
у меня выводит вот что
HTML5
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
  3
        ПнаЯВУ
            3-78-5
            3-78-6
    7
        МО
            7-78-5
            7-78-6
            7-78-7
        физика
            7-78-7
    8
        ПР.Л
            8-78-5
            8-78-6
            8-78-7
проверьте запрос - названия столбцов таблицы

Добавлено через 3 минуты
Цитата Сообщение от TheRealKos Посмотреть сообщение
Теперь выводит
нет групп, проверьте название столбца где группы
0
13.04.2014, 14:32  [ТС]

Не по теме:


Не пускает пока в панель управления базой данных:(. Как только впустит, напишу в чем проблема, на самом ли деле проблема в название столбца, или же что-то другое...

0
 Аватар для fanatikus
1932 / 1523 / 703
Регистрация: 17.11.2012
Сообщений: 6,585
13.04.2014, 14:59
сделайте var_dump($semesters) и посмотрите что у вас в массиве, судя по всему, нет групп
0
2 / 2 / 3
Регистрация: 11.09.2011
Сообщений: 557
13.04.2014, 15:17  [ТС]
Цитата Сообщение от fanatikus Посмотреть сообщение
сделайте var_dump($semesters) и посмотрите что у вас в массиве, судя по всему, нет групп
PHP
1
array(3) { [3]=> array(3) { [0]=> string(6) "ПнаЯВУ" [1]=> string(6) "ПнаЯВУ" [2]=> string(6) "ПнаЯВУ" } [7]=> array(3) { [0]=> string(2) "МО" [1]=> string(2) "МО" [2]=> string(2) "МО" } [8]=> array(3) { [0]=> string(5) "АКиТП" [1]=> string(4) "Пр.Л" [2]=> string(4) "Пр.Л" } }
Добавлено через 3 минуты
Хм...сделал все тоже самое, что и вчера. Скопировал ваш код (спасибо огромное). Теперь же все нормально.

Добавлено через 10 минут
fanatikus, Сейчас уже другой вопрос. Выставил ссылки в меню. И все бы ничего, название предметов на русском, и ссылка идет такого вида http://mysite.ru/index.php?sem... oup=7-78-5. Вместо название предметов, разные символы... Это из-за кодировки или что? И если из-за кодировки, то как подправить?

Хотя такое только в Гугл Хром. В том же ИЕ все нормально...
0
2 / 2 / 3
Регистрация: 11.09.2011
Сообщений: 557
14.04.2014, 23:52  [ТС]
Уважаемый fanatikus, почему-то, если в название есть пробелы (хоть на русском, хоть на английском) в ссылку вставляется только часть до пробела. Пример: должно быть Методы оптимизации, в ссылке идет (и соответственно через GET передает) только Методы...

Добавлено через 15 минут
Собственно вот как ссылки вставляю..
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
<ul>
    <?foreach($semesters as $k => $v):?>
        <li><a href=index.php?semestr=<?=$k?>><?=$k?></a></li>
        <ul>
            <?foreach($v as $k1 => $v1):?>
                <li><a href=index.php?semestr=<?=$k?>&predmet=<?=$k1?>><?=$k1?></a></li>
                <ul>
                    <?foreach($v1 as $k2 => $v2):?>
                        <li><a href=index.php?semestr=<?=$k?>&predmet=<?=$k1?>&group=<?=$v2?>><?=$v2?></a></li>
                    <?endforeach?>
                </ul>
            <?endforeach?>
        </ul>
    <?endforeach?>
</ul>
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
14.04.2014, 23:52
Помогаю со студенческими работами здесь

Организация Древовидного списка в ComboBox
всем привет, как огранизовать combobox на примере как на этом форуме, например при создании темы combobox &quot;Префикс:&quot; с...

Реализация древовидного меню в LCD на МК
Здравствуйте, вобщем у меня есть задание написать меню,которое будет выводиться на lcd экран , для atmega16 , я программист си шарп ,...

Кэширование функции загрузки древовидного меню
Добрый день. Как можно за кэшировать функцию которая выводит древовидное меню.

Создание древовидного меню на сайте в django
Здравствуйте. Есть такая задача: Необходимо создать сайт на Python(Django,Flask) или Java (я выбрал Django!), меню будет состоять из...

Подскажите плагин для бокового древовидного меню
Добрый день. Нужен плагин для бокового дублирующего меню категорий товаров, как на этом сайте, например,...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
26
Ответ Создать тему
Новые блоги и статьи
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ * Дана цепь постоянного тока с сопротивлениями и напряжениями. Надо найти токи в ветвях. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и решает её. Последовательность действий:. . .
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru