0

我正在使用 jsf 2.0。我有这个数据表

<h:dataTable value="#{agreement.licenseProducts}"
    var="licenseProduct"
    styleClass="pnx-table pnx-table-bdr pnx-table-unstyled mp-license-info">
    <h:column>
        <f:facet name="header">
            <h:outputText value="Product" />
        </f:facet>
        <h:outputText value="#{licenseProduct.description}" />
    </h:column>
    <h:column>
        <f:facet name="header">
            <h:outputText value="Serial Number" />
        </f:facet>
        <h:outputText value="#{licenseProduct.serialNumber}" />
    </h:column>
    <h:column>
        <f:facet name="header">
            <h:outputText value="#{agreement.labelForConcurrency}" />
        </f:facet>
        <h:outputText value="#{licenseProduct.concurrent}" />
    </h:column>
    <ui:fragment rendered="#{agreement.managementTool != 'NONE'}">
        <h:column>
            <f:facet name="header">
                <h:outputText value="#{agreement.labelForLicenseType}" />
                <span class="pnx-icon-right pnx-icon-info pnx-tooltip">
                    <div class="pnx-tooltip-content">
                        <h:outputText value="Tooltip content" />
                    </div>
                </span>
            </f:facet>
            <h:outputText value="#{licenseProduct.licenseBase}" />
        </h:column>
    </ui:fragment>
    <h:column>
        <f:facet name="header">
            <h:outputText value="#{agreement.labelForSeatCount}" />
        </f:facet>
        <h:outputText value="#{licenseProduct.seats}" />
    </h:column>
</h:dataTable>

问题是 ui:fragment 部分不起作用。无论属性的值是什么,它都不会显示该列。

有任何想法吗?

- 编辑 -

以防万一,我还有其他 ui:fragments 依赖于相同的属性,并且它们确实根据属性的值正确呈现。我确定它与数据表和列有关。

4

1 回答 1

2

tag的rendered's 属性执行的只是简单的工作:<h:column>

<h:column rendered="#{agreement.managementTool != 'NONE'}">
       ...        
</h:column>
于 2013-09-20T08:24:00.430 回答