我尝试使用codeigniter创建多级菜单这是我用来回显菜单的两个功能。
function loop_array($array = array(), $parent_id = 0) {
if (!empty($array[$parent_id])) {
// echo '<ul>';
foreach ($array[$parent_id] as $items) {
echo '<li><a class = "parent"><span>';
echo $items['label'];
echo '</span></a>';
loop_array($array, $items['id']);
echo '</li>';
}
echo '</ul>';
}
}
function display_menus($menu_items) {
// var_dump($menu_items);
$array = array();
foreach ($menu_items as $rows) {
$array[$rows['parent']][] = $rows;
}
loop_array($array);
}
那么输出的html代码就像
<div id='Mymenu' style=' color: #000; width: 960px; background-image:url(); clear: both; text-align: center; height: 46px;'>
<div id="menu">
<ul class="menu">
<li><a class = "parent"><span>Home</span></a></li><li><a class = "parent"><span>Code</span></a><li><a class = "parent"><span>PHP</span></a><li><a class = "parent"><span>Scripts</span></a><li><a class = "parent"><span>Archive</span></a><li><a class = "parent"><span>Snippet</span></a></li></ul></li></ul></li><li><a class = "parent"><span>Help</span></a></li></ul></li><li><a class = "parent"><span>CSS</span></a></li></ul></li><li><a class = "parent"><span>Contact</span></a></li></ul> </ul>
</div>
</div>
但我需要把它做成
<div id='Mymenu' style=' color: #000; width: 960px; background-image:url(); clear: both; text-align: center; height: 46px;'>
<div id="menu">
<ul class="menu">
<li><a href="index" class="parent"><span>HOME</span></a>
<div><ul>
<li><a href=""><span>Vertical Menu</span></a>
<li><a href=""><span>Slide show</span></a>
</li>
<li><a href="#" class="parent"><span>ABOUT US</span></a></li>
<li><a href="news"><span>NEWS</span></a></li>
<li class="last"><a href="#"><span>ACADEMICS</span></a></li>
<li class="last"><a href="#"><span>PROGRAMME</span></a></li>
<li class="last"><a href="#"><span>ADMISSIONS</span></a></li>
<li class="last"><a href="courses"><span>COURSES</span></a></li>
<li class="last"><a href="contact_us"><span>CONTACT US</span></a></li>
<li class="last"><a href="feedback"><span>Feedback</span></a></li>
</ul>
</div>
有人能给我一个办法吗?
请注意,您的目标代码从一开始就是错误的html(不是封闭的html标记),我不确定它是否真的是您需要或想要的,即它真的是最终正确的形式吗?
此外,如果你清楚地阐述了你的问题,并以可读的格式(而不是一行)编写代码,其他人就不会浪费时间去理解你想要什么。
我假设你有一个树状/多级菜单,你想打印出来区分内部节点(即有子节点或"父节点"的节点)和终端节点(即你的"最后"元素)。
您的*display_menus*函数按其父菜单id对菜单项进行分组,这似乎是正确的。
你的*loop_array*函数似乎就在那里:
function loop_array($array = array(), $parent_id = 0)
{
if (!empty($array[$parent_id]))
{
echo "'n<ul>";
foreach ($array[$parent_id] as $items)
{
// is it a terminal node?
if (empty($array[$items['id']]))
{
$class = 'last';
}
else
{
$class = 'parent';
}
// is there a link?
if (empty($items['my-link-field']))
{
$link = '#';
}
else
{
$link = $items['my-link-field'];
}
// if you do not divide your output string into several statements,
// the code becomes more readable
// I mean
// it
// feels
// like
// several
// fragments
// that
// must
// be seen, understood and put into context. Which -in any language- is just easier with a nice flow.
echo "<li><a class='{$class}' href='{$link}'><span>{$items['label']}</span></a>";
loop_array($array, $items['id']);
echo "</li>'n";
}
echo "</ul>'n";
}
}
如果您仍然没有得到所需的结果,我认为您的数据($menu_items)设置不正确。由于您似乎已经检查过了(注释为var_dump),您可能需要检查传递给loop_array的数据,即$array。