Динамически создавать столбцы таблицы в JSF

Я работаю над приложением панели инструментов, где мне нужно получить набор записей и отобразить их в динамических таблицах. Длина рамки страницы фиксирована. теперь столбцы и строки могут быть инициализированы. Он должен выглядеть так:

enter image description here

В настоящее время я использую таблицу данных для отображения, но она печатает все данные в одном столбце. Как мне изменить код на предыдущий шаблон?

<o:dataTable id="tabBlSearch" var="item"
     onkeyup="handleLeftRightArrowOnDataTable('frmDashBoard:tabBlSearch')"
     value="#{bLDashBoardAction.listBondLoc}">
  <o:column style="width: 20px;">
    <h:outputText value="#{item.awb}" />
  </o:column>
</o:dataTable>

Ответы

Ответ 1

Вы можете добиться этого со стандартными компонентами JSF, используя <h:panelGrid>, где <c:forEach> используется для генерации ячеек в течение времени сборки представления. <ui:repeat> не будет работать так, как это выполняется во время просмотра рендеринга.

<h:panelGrid columns="5">
    <c:forEach items="#{bean.items}" var="item">
        <h:panelGroup>
            <h:outputText value="#{item.value}" />
        </h:panelGroup>
    </c:forEach>
</h:panelGrid>

Что касается библиотек компонентов, я ничего не вижу в витрине OpenFaces, но у PrimeFaces есть <p:dataGrid> для этой цели даже с поддержкой разбивки на страницы.

<p:dataGrid columns="5" value="#{bean.items}" var="item">
    <p:column>
        <h:outputText value="#{item.value}" />
    </p:column>
</p:dataGrid>