0

我尝试使用 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>

谁能给我一个方法来做到这一点?

4

1 回答 1

1

请注意,您的目标代码以错误的 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。

于 2013-08-24T08:09:19.427 回答