Rumah >pangkalan data >tutorial mysql >Bagaimanakah saya boleh mencipta fungsi PHP rekursif untuk menjana pepohon menu hierarki daripada jadual pangkalan data MySQL?
Menggema Pokok Menu dengan Fungsi Rekursif
Untuk menjana pepohon menu hierarki daripada jadual pangkalan data menggunakan fungsi rekursif, pertimbangkan pendekatan berikut:
Masalah:
Anda ingin mencipta fungsi rekursif yang mengekstrak pepohon menu hierarki daripada pangkalan data MySQL.
Situasi:
Jadual mengandungi lajur:
Output HTML Dijangka:
<li><a href="#"><p class="Tier0">Datori</p></a> <ul style="display: block"> <li><a href="#"><p class="Tier1">Cookies</p></a></li> <li><a href="#"><p class="Tier1">Events</p></a></li> <li><a href="#"><p class="Tier1">Forms</p></a></li> <li><a href="#"><p class="Tier1">Games</p></a></li> <li><a href="#"><p class="Tier1">Images</p></a> <ul> <li><a href="#"><p class="Tier2">CSS</p></a></li> <li><a href="#"><p class="Tier2">JavaScript</p></a></li> <li><a href="#"><p class="Tier2">JQuery</p></a></li> </ul> </li> <li><a href="#"><p class="Tier1">Navigations</p></a> <ul> <li><a href="#"><p class="Tier2">CSS</p></a></li> <li><a href="#"><p class="Tier2">JavaScript</p></a></li> <li><a href="#"><p class="Tier2">JQuery</p></a></li> </ul> </li> <li><a href="#"><p class="Tier1">Tabs</p></a></li> </ul> </li> <li><a href="#"><p class="Tier0">Washing Machines</p></a></li>
Fungsi PHP Cadangan:
<code class="php">function recurse($categories, $parent = null, $level = 0) { $ret = '<ul>'; foreach($categories as $index => $category) { if($category['root'] == $parent) { $ret .= '<li><a href="#"><p class="Tier' . $level . '">' . $category['name'] . '</p></a>'; $ret .= $this->recurse($categories, $category['id'], $level+1); $ret .= '</li>'; } } return $ret . '</ul>'; }</code>
Penggunaan:
Pertimbangan Tambahan:
Atas ialah kandungan terperinci Bagaimanakah saya boleh mencipta fungsi PHP rekursif untuk menjana pepohon menu hierarki daripada jadual pangkalan data MySQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!