0

比方说:对于不同上下文中可重复的代码片段重用。我有一个 fragment.xhtml 将包含在多个其他不同的 xhtml 中,比如 main1.xhtml 和 main2.xhtml

fragment.xhtml 为:

<h:body>
  <p:panelGrid id="qualifyGrid">
    <f:facet name="header">
        <p:row>
            <p:column colspan="4">#{staffBean.currentStaff.name} Qualify</p:column>
        </p:row>
    </f:facet>
   ......
    <p:row>
        <p:column styleClass="addlabel"><h:outputLabel for="id" value="#{clientqualify['web.qualify.label.id']}"/></p:column>
        <p:column styleClass="wideField" colspan="3">
            <h:inputText id="id1" value="#{qualifyvalue1}" rendered=""/>
            <h:inputText id="id" value="#{qualifyvalue}" rendered=""/>
        </p:column>
    </p:row>
   ......
    <p:row>
        <p:column styleClass="addlabel"><h:outputLabel for="name" value="#{clientqualify['web.qualify.label.name']}"/></p:column>
        <p:column styleClass="wideField" colspan="3"><p:inputText styleClass="field" id="name" value="#{qualifyControlBean.currentQualify.qualifyName}" required="true"/></p:column>
    </p:row> 
  </p:panelGrid>
</h:body>

main1.xhtml:

<h:body>
  <ui:composition template="/WEB-INF/ozssc-staff-template.xhtml">
    <ui:define name="content">
        <h3>#{clientqualify['web.qualify.edit.heading']}</h3>
        <p:messages id="messages" showDetail="true" autoUpdate="true" />
        <h:form id="qualifyeditform" prependId="false">
            <ui:include src="fragment.xhtml"/>
            <h:panelGrid style="display:block" border="0">
                <p:commandButton id="submit" value="Save" action="#{qualifyControlBean.saveQualify}" icon="fa fa-fw fa-save" ajax="false" disabled="#{qualifyControlBean.currentQualify.status=='Verified'}"/>
            </h:panelGrid>
        </h:form>
    </ui:define>
  </ui:composition>
</h:body>

main2.xhtml

<h:body>
  <ui:composition template="/WEB-INF/ozssc-staff-template.xhtml">
    <ui:define name="content">
        <h3>#{clientqualify['web.qualify.edit.heading']}</h3>
        <p:messages id="messages" showDetail="true" autoUpdate="true" />
        <h:form id="qeditform" prependId="false">
            <ui:include src="fragment.xhtml"/>
            <h:panelGrid style="display:block" border="0">
                <p:commandButton id="submit" value="Save" action="#{qualifyControlBean.saveQualify}" icon="fa fa-fw fa-save" ajax="false" disabled="#{qualifyControlBean.currentQualify.status=='Verified'}"/>
            </h:panelGrid>
        </h:form>
    </ui:define>
  </ui:composition>
</h:body>

从上面你看到的片段中,fragment.xhtml 被包含在两个不同的表单中,在 main1.xhtml 中,表单 id 是“qualifyeditform”,而在 main2.xhtml 中,表单 id 是“qeditform”。

我很难找到一种方法让 fragment.xhtml 元素通过不同的父上下文呈现不同的输入文本。即,如果这个fragment.xhtml 包含在main1.xhtml 中(表单id 为:“qualifyeditform”),则呈现inputText id“id1”。如果这个 fragment.xhtml 包含在 main2.xhtml 中(表单 id 为:“qeditform”),则呈现 inputText id“id”。

如何设置 EL 表达式以查找父表单元素的 id?并在我的 render="" 表达式中使用它?

4

1 回答 1

1

我认为你可以做到

<h:inputText id="id1" 
             value="#{qualifyvalue1}" 
             rendered="#{component.parent.clientId eq 'qualifyeditform'}"/>
于 2016-11-26T10:51:09.490 回答