有条件地渲染tr,使用ui构建表:重复

时间:2013-06-19 13:30:07

标签: jsf-2.2

我正在尝试使用ui:repeat在JSF中手动构建HTML表单。 现在我对“呈现”属性有些麻烦。我的代码如下:

<ui:repeat varStatus="status" value="#{bean.keys}" var="key">
    <tr jsf:rendered="#{status.index%4==0}">
        <td id="#{key}">
             contents
        </td>
    </tr> <!--or even </tr  jsf:rendered="#{status.index%4==0}">-->
</ui:repeat>

我尝试有条件地呈现<tr>标记,但我想在每次迭代时无条件地呈现子元素<td>。我知道它不是JSF的标准行为,因为默认情况下它不会显示未呈现元素的子元素,但是有另一种方法来实现这个要求吗? 我也试过了:

<tr>
    <ui:repeat varStatus="status" value="#{bean.keys}" var="key">
        <td id="#{key}">
             contents
        </td>
        <h:panelgroup rendered="#{status.index%4==0}"></tr><tr></h:panelgroup>
    </ui:repeat>
</tr>

但是最后一个片段不会解析,因为结束是意外的(它需要h:panelgroup的结束标记)

1 个答案:

答案 0 :(得分:1)

将其作为转义HTML发送。

<h:outputText value="&lt;/tr&gt;&lt;tr&gt;" escape="false" rendered="#{status.index%4==0}" />

escape="false"只是为了避免JSF再次将其作为XSS攻击防范的一部分进行转义,这会导致它最终成为&amp;lt;/tr&amp;gt;&amp;lt;tr&amp;gt;