Внутренний UI:repeat не привязывается к компоненту во вложенном UI:repeat
-
20-09-2019 - |
Вопрос
Привет, я использую вложенный интерфейс ui:repeats для отображения своих данных.внешний UI:repeat работает и отлично привязывается к компоненту, но внутренний не привязывается к компоненту.Подводя итог, я хотел бы отобразить список людей, где у каждого человека есть имя и список адресов электронной почты.Вот мой код:
<ui:repeat value="#{myFamily.personList}" var="eachPerson" >
<tr:panelCaptionGroup captionText="#{eachPerson.name}" styleClass="fullWidth">
<h:inputText value="#{eachPerson.age}" styleClass="fullWidth" />
<ui:repeat value="#{eachPerson.emailList}" var="eachEmail" >
<h:panelGrid columns="2">
<h:outputLabel value="#{eachEmail.type}:" styleClass="darkBlue label" />
<h:inputText value="#{eachEmail.email}" maxlength="40" size="38" />
</h:panelGrid>
</ui:repeat>
</tr:panelCaptionGroup>
</ui:repeat>
Привязка к personList прошла нормально, поскольку я тестировал, изменяя возраст каждого человека, и модель менялась после отправки.Однако список адресов электронной почты не меняется, что бы я ни менял на экране.
Пожалуйста помоги!Я использую JSF, Spring Web Flow, Facelets и Trinidad.
Решение
Спасибо за быстрый ответ.Проведя некоторое время в Google, я обнаружил, что вложенный UI:repeat хорошо поддерживается.Вы можете использовать различные альтернативы, такие как tr:iterator, c:forEach и/или tr:forEach.
Я хотел бы прояснить одну вещь: c:forEach и ui:repeat привязывают значения к поддерживающим компонентам и хорошо поддерживаются в jsf и facelets.