在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>
树。我需要胶水。
答案 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>