Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: Вывод родительской категории

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


 Страниц (1): [1]   

> Без описания
allforweb
Отправлено: 06 Апреля, 2011 - 23:53:06
Post Id


Гость


Покинул форум
Сообщений всего: 108
Дата рег-ции: Сент. 2010  


Помог: 0 раз(а)




Подскажите с решением такой задачи:
есть категории и подкатегории со структурой таблицы в БД id - name - parent (категория родитель, если она равна 0, это категория, если нет - подкатегория). Добавление категории сделал, а вот задачу по модулю редактирования уже созданных категорий решить не могу.

Как сделать чтобы при редакировании категории выводилась в выпадающем списке категория родитель с элементом selected, т.е. чтобы видно было кто родитель подкатегории.

Первую часть кода написал, если родителя нет:
PHP:
скопировать код в буфер обмена
  1. while ($myrow = mysql_fetch_assoc($result)) {
  2.                                  if ($myrow['parent'] == 0) {
  3.           $cat .='<option value="'. $myrow['id_cat'] .'">'. $myrow['name'] .'</option>';              
  4.                                  } else {
  5.           а вто здесь уже проблема
  6.                                  }
 
 Top
Мелкий Супермодератор
Отправлено: 07 Апреля, 2011 - 00:13:48
Post Id



Активный участник


Покинул форум
Сообщений всего: 11926
Дата рег-ции: Июль 2009  
Откуда: Россия, Санкт-Петербург


Помог: 618 раз(а)




перед именем категории выведите какой-нибудь разграничитель. Например как на этом форуме формочка "переход по форумам":
раздел
-- подраздел
-- подраздел


-----
PostgreSQL DBA
 
 Top
allforweb
Отправлено: 07 Апреля, 2011 - 00:22:07
Post Id


Гость


Покинул форум
Сообщений всего: 108
Дата рег-ции: Сент. 2010  


Помог: 0 раз(а)




Мелкий пишет:
еред именем категории выведите какой-нибудь разграничитель. Например как на этом форуме формочка "переход по форумам":
раздел


Я имел ввиду как ее определить, писать html теги я умею.
 
 Top
Мелкий Супермодератор
Отправлено: 07 Апреля, 2011 - 00:42:12
Post Id



Активный участник


Покинул форум
Сообщений всего: 11926
Дата рег-ции: Июль 2009  
Откуда: Россия, Санкт-Петербург


Помог: 618 раз(а)




а. Рекурсивно в любом случае. Варианта 2:
0) простой для БД, но надо больше памяти скрипту:
выбираем все записи из таблицы, собираем в многомерный массив примерно такой:
$array[ ид_родительской_категории ][] = массив полей из бд.
Тогда строится примерно так:
PHP:
скопировать код в буфер обмена
  1. function tree($parent) {
  2. global $array;
  3. foreach ($array[$parent] as $el) {
  4. if (isset($array[ $el['id'] ])) tree($el['id']);
  5. else echo $el['name'];
  6. }
  7. }

ну рюшечками обвещаете

1) много запросов к БД:
для каждой категории делаем запрос в БД, есть ли подкатегории для этой категории.


-----
PostgreSQL DBA
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Программирование на PHP »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB