如何使用ui重复子列表:重复?

时间:2013-04-08 09:11:20

标签: jsf-2

我正在迁移一段看起来像这样的遗留代码:

<c:forEach items="#{sel}" var="crit" end="12">
  <tr>
    <td class="criteriaName">
      <c:set var="tip" value="#{Factory.makeTooltip(crit.string)}" />

      <c:if test="#{0 != fn:length(tip)}">
        <a:outputPanel layout="block">
          <h:outputText value="#{crit.kriterium}" styleClass="tooltipAvailable"/>
            <rich:tooltip layout="block">
              <h:outputText escape="false" value="#{tip}" />
            </rich:tooltip>
         </a:outputPanel>
       </c:if>

       <c:if test="#{0 == fn:length(tip)}">
         <h:outputText value="#{crit.kriterium}" />
       </c:if>
     </td>
  </tr>
</c:forEach>

现在,我希望将<c:if><c:forEach>替换为<ui:fragment><ui:repeat>对应方。问题是,我需要迭代sel两次:一次从0到12再从13到结束。

我还没有找到一种方法来分割列表迭代,就像foreach标记的end属性那样。我真的想避免在后端拆分列表,因为这是一个纯粹的视图问题,应该在那里处理。

所以问题是:我可以按照指定的方式替换上面的片段吗?有哪些替代方案?

1 个答案:

答案 0 :(得分:5)

如果您使用的是EL 2.2,则可以调用普通的java方法。

假设此处selList,您可以使用

<ui:repeat var="crit" value="#{sel.subList(0,12)}">

并非ui:repeatc:forEach并非总是可以互换,因此请确保您的用例有效。