Проблема с рекурсивной функцией php: работает безрезультатно - PullRequest
2 голосов
/ 14 сентября 2011

Моя таблица БД выглядит так. Я пытаюсь создать навигацию. меню из таблицы БД. Вот мой скриншот таблицы

enter image description here

Я хочу получить что-то подобное

<li><a href="?page=1">Level 1</a>
  <ul>
   <li><a href="?page=2">Level2</a>
     <ul>
       <li><a href="?page=3">Level3</a></li> 
     </ul>
   </li>
  </ul>
</li>

А вот моя рекурсивная функция php, которая генерирует функцию nav.

<!doctype html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
</head>
<?php
require 'core/includes/db.php';
function menu($parent, $level){
  global $db;
  $q = $db->query("select * from menu where parent = '$parent'");
  if($level > 0 && $q->num_rows > 0){
    echo '<ul>';
  }
  while($row=$q->fetch_object()){
    echo "<li>".$q->name."</li>"; (line 14)
    //display this level's children
    menu($q->id, $level+1); (line 16)
  }
  if($level > 0 &&  $q->num_rows > 0){
    echo '</ul>';
  }
}
echo '<ul>' . menu(0,0) . '</ul>'

?>

На самом деле это ничего не генерирует. Он работает рекурсивно и получает кучу ошибок в логах php.

[15-Sep-2011 00:47:22] PHP Notice:  Undefined property: mysqli_result::$id in E:\Web Server\smiths-heimann.az\nav.php on line 16
[15-Sep-2011 00:47:22] PHP Notice:  Undefined property: mysqli_result::$name in E:\Web Server\smiths-heimann.az\nav.php on line 14

Что не так с моей функцией? Пожалуйста, помогите исправить это

UPDATE Финальный PHP-код

<!doctype html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
</head>
<?php
require 'core/includes/db.php';
function menu($parent, $level){
  global $db;
  $q = $db->query("select * from menu where parent = '$parent'");
  if($level > 0 && $q->num_rows > 0){
    echo '<ul>';
  }
while($row=$q->fetch_object()){
    echo "<li>";
    echo '<a href="?page=' . $row->id . '">' . $row->name . '</a>';
    //display this level's children
    menu($row->id, $level+1);
    echo "</li>\n";
}
  if($level > 0 &&  $q->num_rows > 0){
    echo '</ul>';
  }
}
echo '<ul>' . menu(0,0) . '</ul>'

?>


 </html>

OK. Теперь я получаю то, что хочу. Большое спасибо, Адам. Но в конце страницы есть 3 пары пустых. Почему они появляются? Пожалуйста, посмотрите

<!doctype html>

<head>

<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />

</head>

<li><a href="?page=1">Ana Səhifə</a></li> 
<li><a href="?page=2">Təftiş texnikası</a><ul><li><a href="?page=3">Təhlükə üzrə sıralanma</a></li> 
</ul></li> 
<li><a href="?page=4">Istifadə olunan texnologiyalar</a><ul><li><a href="?page=5">Qamma şüa spektroskopiyası</a></li> 
<li><a href="?page=6">Portativ Ion Spektrometri</a></li> 
<li><a href="?page=7">İnfra qırmızı</a></li> 
<li><a href="?page=8">Mikrodalğa</a></li> 
<li><a href="?page=9">Raman Spektroskopiyası</a></li> 
<li><a href="?page=10">Rentgen araşdırma sistemləri</a><ul><li><a href="?page=11">Məktub və Banderolların yoxlanışı</a></li> 
<li><a href="?page=12">HiTraX Texnologiyası</a></li> 
</ul></li> 
</ul></li> 
<ul></ul>



 </html>

1 Ответ

5 голосов
/ 14 сентября 2011

В обеих строках 14 и 16 смешаны значения $q и $row. Каждый раз, когда выполняется цикл while, текущий объект (из $q->fetch_object()) помещается в $row.Я также обновил свой ответ, чтобы он лучше соответствовал требуемому результату в (обновленном) вопросе

while($row=$q->fetch_object()){
    echo "<li>";
    echo '<a href="?page=' . $row->id . '">' . $row->name . '</a>';
    //display this level's children
    menu($row->id, $level+1);
    echo "</li>";
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...