1

我正在使用 masterDetail-component 来显示一些东西。首先,我将整个 masterDetail-Component 嵌套在 -Tag 中。在我注意到我必须在 masterDetail 组件中使用表单后,我删除了表单标签以避免嵌套表单,这是不允许的。

<ui:define name="center">
        <p:growl id="infoMessage" sticky="false" />
        <p:layoutUnit position="center" style="border-width: 0px">

            <p:panel id="panel">

                <pe:masterDetail showBreadcrumb="true" selectLevelListener="#{logic.selectLevel}">

                    <f:facet name="header">
                        <p:messages showDetail="false" showSummary="true" />
                    </f:facet>

                    <pe:masterDetailLevel level="1"
                        levelLabel="#{ivy.cms.co('/Labels/Mitarbeiterauswahl')}">
                        <h:panelGrid columns="3" cellpadding="5">

                            <p:outputLabel for="name" value="#{ivy.cms.co('/Labels/Mitarbeiter')}" />
                            <p:inputText id="name" value="#{data.nameSuche}" />
                            <p:commandButton value="#{ivy.cms.co('/Labels/Buttons/Suchen')}"
                                actionListener="#{logic.RD_Suchen}" update="mitarbeitersuche" />

                        </h:panelGrid>

                        <p:dataTable value="#{data.mitarbeiter.rsMitarbeiter}" var="mitarbeiter"
                            id="mitarbeitersuche">
                            <p:column headerText="#{ivy.cms.co('/Labels/Nachname')}">
                                <h:outputText value="#{mitarbeiter['nachnamemita']}" />
                            </p:column>

                            <p:column headerText="#{ivy.cms.co('/Labels/Vorname')}">
                                <h:outputText value="#{mitarbeiter['vornamemita']}" />
                            </p:column>

                            <p:column headerText="#{ivy.cms.co('/Labels/Kostenstellennr')}">
                                <h:outputText value="#{mitarbeiter['nrkost']}" />
                            </p:column>

                            <p:column headerText="#{ivy.cms.co('/Labels/Kostenstelle')}">
                                <h:outputText value="#{mitarbeiter['beschreibungkost']}" />
                            </p:column>

                            <p:column headerText="#{ivy.cms.co('/Labels/email')}">
                                <h:outputText value="#{mitarbeiter['emailmita']}" />
                            </p:column>

                        </p:dataTable>

                    </pe:masterDetailLevel>


                </pe:masterDetail>


            </p:panel>

        </p:layoutUnit>
    </ui:define>

现在抛出异常:

MenuItem must be inside a form element

viewId=/instances/13ED0EF71F61E4D5/MitarbeiterdatenJSF.xhtml location=C:\Users\nweis.FREICON\Desktop\xivy5\webapps\ivy\instances\13ED0EF71F61E4D5\MitarbeiterdatenJSF.xhtml phaseId=RENDER_RESPONSE(6)

原因:javax.faces.FacesException - MenuItem 必须位于 org.primefaces.component.menu.BaseMenuRenderer.encodeMenuItem(BaseMenuRenderer.java:92) 的表单元素内

这真的让我很困惑,因为在 PrimefacesExtension-Team 提供的代码示例中,pe:masterDetail 周围没有表单元素,请参见此处。也许有人可以帮我一把。

4

1 回答 1

2

当然,我们有一个围绕 pe:masterDetail 的表单元素。很简单,没有在代码中显示,因为表单在主模板中。当然,MenuItem 应该在一个表单中,因此也应该在整个 MasterDetail 中。MenuItem 是一个命令组件,每个命令组件都应该在一个表单中。

于 2013-05-23T15:05:23.563 回答