来自NavigableMap的构建菜单

时间:2019-01-30 15:12:12

标签: grails gsp

在Grails 3.3应用程序中,我试图创建菜单配置,并且我想为此使用application.groovy。

application.groovy:

mainmenuconfig {
    menuitem_1 {
        id = 'menuitem-1'
        name='Home'
        sub=null
    }
    menuitem_2 {
        id ='menuitem-2'
        name='Stammdaten'
        sub = submenuitem_2 {
            menuitem_2_1 {
                id = 'menuitem-2-1'
                name ='Stamm-A'
                sub=null
            }
    }}
}

通过grailsApplication.config.get('mainmenuconfig')检索配置将为我提供以下信息:

[menuitem_1:[id:menuitem-1, name:Home, sub:null], menuitem_2:[id:menuitem-2, name:Stammdaten, submenuitem_2:[menuitem_2_1:[id:menuitem-2-1, name:Stamm-A]], sub:null]]

如果我看着getClass(),它说是org.grails.config.NavigableMap

现在,据我了解,应该在View层内部生成<UL> ... <LI>树。为了遍历该结构,我将需要递归,因为它可以深达n级。

如果我从main.gsp看,我知道要插入菜单树的位置,但是如何将数据带到那里,又该在哪里进行递归?我需要从GSP调用的菜单控制器吗?恕我直言,GSP不应进行此类呼叫。另一方面,任何控制器都不应生成<UL> ... <LI>树。我需要胶水。

1 个答案:

答案 0 :(得分:2)

这听起来像interceptor的好用法。每个动作完成后,可以将其添加到模型中。然后,您的视图将可以访问其模型中的menu并可以构建菜单。如果出于显示目的,可以在视图中进行递归。

class NavigationMenuInterceptor {

    NavigationMenuInterceptor() {
        matchAll()
    }

    boolean after() {
        model.menu = grailsApplication.config.getProperty('mainmenuconfig', Map)
        true
    }
}

要呈现菜单,您可以使用递归呈现自身的模板。根据您所需的HTML输出,可能如下所示。

在主体中:

<ul>
    <g:each in="${menu}" var="menuitem">
        <g:render template="menuitem" model="[menuitem: menuitem]"/>
    </g:each>
</ul>

在模板_menuitem.gsp中:

<li id="${menuitem.id}">
    ${menuitem.name}
</li>
<g:if test="${menuitem.sub}">
    <li>
        <ul>
            <g:render template="menuitem" model="[menuitem: menuitem.sub]"/>
        </ul>
    </li>
</g:if>