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
Форумы портала PHP.SU :: Версия для печати :: Помогите построить дерево
Форумы портала PHP.SU » PHP » Программирование на PHP » Помогите построить дерево

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

1. michael - 02 Ноября, 2007 - 11:27:20 - перейти к сообщению
Имеется таблица, содержащая столбец Id, parentId, name. Как построить дерево?Помогите... подскажите... как лучше...
2. evgenijj - 02 Ноября, 2007 - 11:49:24 - перейти к сообщению
PHP:
скопировать код в буфер обмена
  1.  
  2. // Получаем дерево категорий
  3. $categories = get_ctgs_tree( 0, 0 );
  4.        
  5. echo "<h3>Дерево каталога</h3>\\n";
  6. foreach ( $categories as $ctg )
  7. {
  8.     // выводим массив
  9.     // $ctg[0] - уникальный ID категории
  10.     // $ctg[1] - наименование категории
  11.     // $ctg[2] - описание
  12.     // $ctg[3] - уровень вложенности (чтобы делать отступы)
  13. }
  14.  
  15. // Функция возвращает дерево категорий в виде массива
  16. function get_ctgs_tree($parent, $level)
  17. {
  18.         $query = "SELECT id_ctg, name, description FROM ".TABLE_CATEGORIES." WHERE id_parent=".$parent." ORDER BY orders";
  19.         $res = mysql_query( $query ) or die (mysql_error());
  20.         $ctg = array(); // категории
  21.         while ($row = mysql_fetch_row($q))
  22.         {
  23.                 // Уровень вложенности категории
  24.                 $row[3] = $level;
  25.                 $ctg[] = $row;
  26.                 // получаем подкатегории для текущей категории
  27.                 $children = get_ctgs_tree($row[0], $level+1);
  28.                 // добавляем детей текущей категории в конец массива $ctg[]
  29.                 for ($j=0; $j<count($children); $j++)
  30.                 {
  31.                         $ctg[] = $children[$j];
  32.                 }
  33.         }
  34.         return $ctg;
  35. }
  36.  

 

Powered by ExBB FM 1.0 RC1