Primefaces:混合静态和动态菜单条目

时间:2017-11-01 22:54:40

标签: primefaces jsf-2.2

我想在标记中保留我的菜单的一部分静态,并在Java中动态生成另一部分。

<p:menubar>
    <p:menuitem value="static stuff"/>
    <p:submenu label="dynamic stuff" model="#{bean.dynamicMenu}"/>
    <!-- more static stuff -->
</p:menubar>

这仅显示静态项,并且从不调用我的getDynamicMenu方法,因为p:submenu不会使用model属性。

我尝试在菜单结构中使用ui:include将标记移动到一个额外的文件中并将其包含在不同的上下文中,但Primefaces抱怨它不喜欢它作为p:menubar的子元素和/或p:submenu

如何在xhtml中保持菜单的一部分静态,在Java中保持部分动态?

1 个答案:

答案 0 :(得分:0)

虽然我无法使用ui:include,但我可以使用c:forEach,正如@Kukeltje在评论中指出的那样:

<p:submenu label="Dynamic 0" rendered="#{list.size() eq 0">
    <p:menuitem value="Nothing here..." url="...">
</p:submenu>

<p:submenu label="Dynamic 1" rendered="#{list.size() eq 1}">
    <c:set var="node" value="#{list[0]}"/>
    <!-- more menu structure here -->
</p:submenu>

<p:submenu label="Dynamic N" rendered="#{list.size() gt 1}">
    <c:forEach items="#{list}" var="item">
        <p:submenu label="#{item}">
            <!-- more menu structure here -->
        </p:submenu>
    </c:forEach>
</p:submenu>

这允许我根据我的支持bean提供不同的菜单。

再次感谢,@ Kukeltje!